~drizzle-trunk/drizzle/development

1 by brian
clean slate
1
/* Copyright (C) 2000-2003 MySQL AB
2
3
   This program is free software; you can redistribute it and/or modify
4
   it under the terms of the GNU General Public License as published by
5
   the Free Software Foundation; version 2 of the License.
6
7
   This program is distributed in the hope that it will be useful,
8
   but WITHOUT ANY WARRANTY; without even the implied warranty of
9
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10
   GNU General Public License for more details.
11
12
   You should have received a copy of the GNU General Public License
13
   along with this program; if not, write to the Free Software
14
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
15
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
16
#include "config.h"
17
319.1.1 by Grant Limberg
renamed all instances of MYSQL_ to DRIZZLE_
18
#define DRIZZLE_LEX 1
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
19
1241.9.57 by Monty Taylor
Oy. Bigger change than I normally like - but this stuff is all intertwined.
20
#include <drizzled/my_hash.h>
549 by Monty Taylor
Took gettext.h out of header files.
21
#include <drizzled/error.h>
553.1.3 by Monty Taylor
Split out nested_join.h.
22
#include <drizzled/nested_join.h>
561.1.3 by Monty Taylor
Split some more things out of common_includes.h.
23
#include <drizzled/query_id.h>
1336.2.2 by Jay Pipes
NO CODE CHANGES - Simply moves pieces of ReplicationServices to TransactionServices. Preparation for making the ReplicationServices component only responsible for communication between replicators, appliers, publishers, and subscribers.
24
#include "drizzled/transaction_services.h"
520.8.2 by Monty Taylor
Moved sql_parse.h and sql_error.h out of common_includes.
25
#include <drizzled/sql_parse.h>
520.6.7 by Monty Taylor
Moved a bunch of crap out of common_includes.
26
#include <drizzled/data_home.h>
575.4.7 by Monty Taylor
More header cleanup.
27
#include <drizzled/sql_base.h>
28
#include <drizzled/show.h>
1235.4.23 by Stewart Smith
fix includes for drizzled/db.h. Now only in .cc files, no header files. should make modifying db.h much less painful.
29
#include <drizzled/db.h>
670.1.20 by Monty Taylor
Renamed functions to function... everything else is singular.
30
#include <drizzled/function/time/unix_timestamp.h>
31
#include <drizzled/function/get_system_var.h>
584.4.7 by Monty Taylor
Removed a big bank of includes from item.h.
32
#include <drizzled/item/cmpfunc.h>
642.1.20 by Lee
header file clean up
33
#include <drizzled/item/null.h>
584.1.15 by Monty Taylor
The mega-patch from hell. Renamed sql_class to session (since that's what it is) and removed it and field and table from common_includes.
34
#include <drizzled/session.h>
35
#include <drizzled/sql_load.h>
670.2.4 by Monty Taylor
Removed more stuff from the headers.
36
#include <drizzled/lock.h>
837 by Brian Aker
Reworked some classes out of session.h
37
#include <drizzled/select_send.h>
971.6.1 by Eric Day
Renamed Protocol to Client, cleaned up some unnecessary methods along the way.
38
#include <drizzled/plugin/client.h>
1100.3.30 by Padraig O'Sullivan
Renamed the Command class to be Statement. Renamed the command directory to
39
#include <drizzled/statement.h>
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
40
#include <drizzled/statement/alter_table.h>
1126.10.18 by Padraig O'Sullivan
Various small build fixes for when dtrace is enabled.
41
#include "drizzled/probes.h"
1241.9.17 by Monty Taylor
Removed more bits from server_includes.
42
#include "drizzled/session_list.h"
1241.9.28 by Monty Taylor
Removed global_charset_info.h from server_includes.h
43
#include "drizzled/global_charset_info.h"
1100.3.1 by Padraig O'Sullivan
Beginnings of reworking the mysql_execute_command() method.
44
1130.1.12 by Monty Taylor
Moved service stuff into plugin/
45
#include "drizzled/plugin/logging.h"
1307.1.2 by Padraig O'Sullivan
Added the plugin point for the query rewriting interface.
46
#include "drizzled/plugin/query_rewrite.h"
1643.6.1 by Djellel E. Difallah
Added hook points and the interface for the Query Cache plugin
47
#include "drizzled/plugin/query_cache.h"
1317.2.6 by Monty Taylor
Prevent the user from attempting to kill a process that he is not authorized
48
#include "drizzled/plugin/authorization.h"
1240.7.1 by Padraig O'Sullivan
Created an ExplainPlan class in the optimizer namespace. All printing of an explain in drizzle goes
49
#include "drizzled/optimizer/explain_plan.h"
1241.9.31 by Monty Taylor
Moved global pthread variables into their own header.
50
#include "drizzled/pthread_globals.h"
1130.1.1 by Monty Taylor
Merged in plugin-slot-reorg patches.
51
1241.9.59 by Monty Taylor
Removed the first mystrings header.
52
#include <limits.h>
53
590.2.18 by Monty Taylor
Changed the bitset<32> to a bitset<5>. Made the int constants into bitset constants.
54
#include <bitset>
1067.4.4 by Nathan Williams
The rest of the files in the drizzled directory were purged of the cmin macro and replace with std::min (except for the definition in globals.h and 1 usage in stacktrace.cc).
55
#include <algorithm>
590.2.18 by Monty Taylor
Changed the bitset<32> to a bitset<5>. Made the int constants into bitset constants.
56
1241.9.64 by Monty Taylor
Moved remaining non-public portions of mysys and mystrings to drizzled/internal.
57
#include "drizzled/internal/my_sys.h"
1241.9.62 by Monty Taylor
Removed plugin/myisam/myisam.h from session.h
58
590.2.18 by Monty Taylor
Changed the bitset<32> to a bitset<5>. Made the int constants into bitset constants.
59
using namespace std;
584.1.15 by Monty Taylor
The mega-patch from hell. Renamed sql_class to session (since that's what it is) and removed it and field and table from common_includes.
60
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
61
extern int DRIZZLEparse(void *session); // from sql_yacc.cc
62
63
namespace drizzled
64
{
65
1039.1.16 by Brian Aker
A lot of little cleanups (most based off lcov)
66
/* Prototypes */
1085.1.2 by Monty Taylor
Fixed -Wmissing-declarations
67
bool my_yyoverflow(short **a, YYSTYPE **b, ulong *yystacksize);
1165.1.48 by Stewart Smith
make parse_sql static to sql_parse.cc
68
static bool parse_sql(Session *session, Lex_input_stream *lip);
1280.3.17 by Padraig O'Sullivan
Merged from Monty
69
void mysql_parse(Session *session, const char *inBuf, uint32_t length);
1085.1.2 by Monty Taylor
Fixed -Wmissing-declarations
70
1 by brian
clean slate
71
/**
72
  @defgroup Runtime_Environment Runtime Environment
73
  @{
74
*/
75
629.2.7 by Monty Taylor
Fixed a couple of memory buffer size issues.
76
extern size_t my_thread_stack_size;
520.6.7 by Monty Taylor
Moved a bunch of crap out of common_includes.
77
extern const CHARSET_INFO *character_set_filesystem;
1 by brian
clean slate
78
230.1.8 by Monty Taylor
Set length to catch errors in adding or removing COM_* constants.
79
const LEX_STRING command_name[COM_END+1]={
1 by brian
clean slate
80
  { C_STRING_WITH_LEN("Sleep") },
81
  { C_STRING_WITH_LEN("Quit") },
82
  { C_STRING_WITH_LEN("Init DB") },
83
  { C_STRING_WITH_LEN("Query") },
84
  { C_STRING_WITH_LEN("Shutdown") },
85
  { C_STRING_WITH_LEN("Connect") },
86
  { C_STRING_WITH_LEN("Ping") },
87
  { C_STRING_WITH_LEN("Error") }  // Last command number
88
};
89
90
const char *xa_state_names[]={
91
  "NON-EXISTING", "ACTIVE", "IDLE", "PREPARED"
92
};
93
94
/**
95
  Mark all commands that somehow changes a table.
96
97
  This is used to check number of updates / hour.
98
99
  sql_command is actually set to SQLCOM_END sometimes
100
  so we need the +1 to include it in the array.
101
102
  See COMMAND_FLAG_xxx for different type of commands
103
     2  - query that returns meaningful ROW_COUNT() -
104
          a number of modified rows
105
*/
590.2.18 by Monty Taylor
Changed the bitset<32> to a bitset<5>. Made the int constants into bitset constants.
106
bitset<CF_BIT_SIZE> sql_command_flags[SQLCOM_END+1];
1 by brian
clean slate
107
108
void init_update_queries(void)
109
{
610 by Brian Aker
Merge of Monty's (plus fix for increment style/useless +1)
110
  uint32_t x;
111
112
  for (x= 0; x <= SQLCOM_END; x++)
113
    sql_command_flags[x].reset();
1 by brian
clean slate
114
115
  sql_command_flags[SQLCOM_CREATE_TABLE]=   CF_CHANGES_DATA;
116
  sql_command_flags[SQLCOM_CREATE_INDEX]=   CF_CHANGES_DATA;
117
  sql_command_flags[SQLCOM_ALTER_TABLE]=    CF_CHANGES_DATA | CF_WRITE_LOGS_COMMAND;
118
  sql_command_flags[SQLCOM_TRUNCATE]=       CF_CHANGES_DATA | CF_WRITE_LOGS_COMMAND;
119
  sql_command_flags[SQLCOM_DROP_TABLE]=     CF_CHANGES_DATA;
120
  sql_command_flags[SQLCOM_LOAD]=           CF_CHANGES_DATA;
121
  sql_command_flags[SQLCOM_CREATE_DB]=      CF_CHANGES_DATA;
122
  sql_command_flags[SQLCOM_DROP_DB]=        CF_CHANGES_DATA;
123
  sql_command_flags[SQLCOM_RENAME_TABLE]=   CF_CHANGES_DATA;
124
  sql_command_flags[SQLCOM_DROP_INDEX]=     CF_CHANGES_DATA;
125
126
  sql_command_flags[SQLCOM_UPDATE]=	    CF_CHANGES_DATA | CF_HAS_ROW_COUNT;
127
  sql_command_flags[SQLCOM_INSERT]=	    CF_CHANGES_DATA | CF_HAS_ROW_COUNT;
128
  sql_command_flags[SQLCOM_INSERT_SELECT]=  CF_CHANGES_DATA | CF_HAS_ROW_COUNT;
129
  sql_command_flags[SQLCOM_DELETE]=         CF_CHANGES_DATA | CF_HAS_ROW_COUNT;
130
  sql_command_flags[SQLCOM_REPLACE]=        CF_CHANGES_DATA | CF_HAS_ROW_COUNT;
131
  sql_command_flags[SQLCOM_REPLACE_SELECT]= CF_CHANGES_DATA | CF_HAS_ROW_COUNT;
132
133
  sql_command_flags[SQLCOM_SHOW_WARNS]= CF_STATUS_COMMAND;
134
  sql_command_flags[SQLCOM_SHOW_ERRORS]= CF_STATUS_COMMAND;
135
  sql_command_flags[SQLCOM_SHOW_CREATE_DB]=  CF_STATUS_COMMAND;
136
  sql_command_flags[SQLCOM_SHOW_CREATE]=  CF_STATUS_COMMAND;
137
138
  /*
139
    The following admin table operations are allowed
140
    on log tables.
141
  */
142
  sql_command_flags[SQLCOM_ANALYZE]=          CF_WRITE_LOGS_COMMAND;
143
}
144
145
/**
146
  Perform one connection-level (COM_XXXX) command.
147
148
  @param command         type of command to perform
520.1.22 by Brian Aker
Second pass of thd cleanup
149
  @param session             connection handle
1 by brian
clean slate
150
  @param packet          data for the command, packet is always null-terminated
151
  @param packet_length   length of packet + 1 (to show that data is
152
                         null-terminated) except for COM_SLEEP, where it
153
                         can be zero.
154
155
  @todo
520.1.22 by Brian Aker
Second pass of thd cleanup
156
    set session->lex->sql_command to SQLCOM_END here.
1 by brian
clean slate
157
  @todo
158
    The following has to be changed to an 8 byte integer
159
160
  @retval
161
    0   ok
162
  @retval
163
    1   request of thread shutdown, i. e. if command is
164
        COM_QUIT/COM_SHUTDOWN
165
*/
520.1.22 by Brian Aker
Second pass of thd cleanup
166
bool dispatch_command(enum enum_server_command command, Session *session,
561.1.3 by Monty Taylor
Split some more things out of common_includes.h.
167
                      char* packet, uint32_t packet_length)
1 by brian
clean slate
168
{
169
  bool error= 0;
561.1.3 by Monty Taylor
Split some more things out of common_includes.h.
170
  Query_id &query_id= Query_id::get_query_id();
1 by brian
clean slate
171
1126.10.2 by Padraig O'Sullivan
Added hooks into the command start and query start dtrace probes.
172
  DRIZZLE_COMMAND_START(session->thread_id,
173
                        command);
174
175
  session->command= command;
520.1.22 by Brian Aker
Second pass of thd cleanup
176
  session->lex->sql_command= SQLCOM_END; /* to avoid confusing VIEW detectors */
177
  session->set_time();
1273.1.1 by Jay Pipes
* Changes Session::warn_id to Session::warn_query_id
178
  session->setQueryId(query_id.value());
1 by brian
clean slate
179
180
  switch( command ) {
181
  /* Ignore these statements. */
182
  case COM_PING:
183
    break;
184
  /* Increase id and count all other statements. */
185
  default:
1689.5.1 by Joseph Daly
remove increment calls
186
    session->status_var.questions++;
561.1.3 by Monty Taylor
Split some more things out of common_includes.h.
187
    query_id.next();
1 by brian
clean slate
188
  }
189
520.1.22 by Brian Aker
Second pass of thd cleanup
190
  /* TODO: set session->lex->sql_command to SQLCOM_END here */
1 by brian
clean slate
191
1130.1.16 by Monty Taylor
Fixed naming issue.
192
  plugin::Logging::preDo(session);
383.6.4 by Mark Atwood
more make plug logging work
193
520.1.22 by Brian Aker
Second pass of thd cleanup
194
  session->server_status&=
1 by brian
clean slate
195
           ~(SERVER_QUERY_NO_INDEX_USED | SERVER_QUERY_NO_GOOD_INDEX_USED);
196
  switch (command) {
197
  case COM_INIT_DB:
198
  {
1302.4.8 by Eric Day
Added prototest test case for mysql_protocol.
199
    if (packet_length == 0)
200
    {
201
      my_message(ER_NO_DB_ERROR, ER(ER_NO_DB_ERROR), MYF(0));
202
      break;
203
    }
204
1273.19.29 by Brian Aker
Code style cleanup.
205
    string tmp(packet, packet_length);
206
1415 by Brian Aker
Mass overhaul to use schema_identifier.
207
    SchemaIdentifier identifier(tmp);
208
209
    if (not mysql_change_db(session, identifier))
1 by brian
clean slate
210
    {
836 by Brian Aker
Fixed session call from function to method.
211
      session->my_ok();
1 by brian
clean slate
212
    }
213
    break;
214
  }
215
  case COM_QUERY:
216
  {
934.2.9 by Jay Pipes
Pulls alloc_query() C function out of sql_parse.cc and adds readAndStoreQuery() member method of Session class.
217
    if (! session->readAndStoreQuery(packet, packet_length))
1 by brian
clean slate
218
      break;					// fatal error is set
1280.3.16 by Padraig O'Sullivan
Updated the calls to dtrace probes to use the c_str() pointer from query in Session
219
    DRIZZLE_QUERY_START(session->query.c_str(),
1126.10.2 by Padraig O'Sullivan
Added hooks into the command start and query start dtrace probes.
220
                        session->thread_id,
1241.7.2 by Padraig O'Sullivan
Corrected a dtrace probe now that db is std::string and not char * in the Session class.
221
                        const_cast<const char *>(session->db.empty() ? "" : session->db.c_str()));
1 by brian
clean slate
222
1307.1.6 by Padraig O'Sullivan
Updated the query rewriting API based on a suggestion from Jay to pass the schema the Session is currently in after seeing the result of rewriting plugin Padraig developed.
223
    plugin::QueryRewriter::rewriteQuery(session->db, session->query);
1280.3.13 by Padraig O'Sullivan
Removed the found_semicolon member from the parsing stage
224
    mysql_parse(session, session->query.c_str(), session->query.length());
1 by brian
clean slate
225
226
    break;
227
  }
228
  case COM_QUIT:
229
    /* We don't calculate statistics for this command */
520.1.22 by Brian Aker
Second pass of thd cleanup
230
    session->main_da.disable_status();              // Don't send anything back
55 by brian
Update for using real bool types.
231
    error=true;					// End server
1 by brian
clean slate
232
    break;
233
  case COM_SHUTDOWN:
234
  {
1689.5.1 by Joseph Daly
remove increment calls
235
    session->status_var.com_other++;
836 by Brian Aker
Fixed session call from function to method.
236
    session->my_eof();
1039.1.16 by Brian Aker
A lot of little cleanups (most based off lcov)
237
    session->close_thread_tables();			// Free before kill
575.4.4 by Yoshinori Sano
Rename mysql to drizzle.
238
    kill_drizzle();
55 by brian
Update for using real bool types.
239
    error=true;
1 by brian
clean slate
240
    break;
241
  }
242
  case COM_PING:
1689.5.1 by Joseph Daly
remove increment calls
243
    session->status_var.com_other++;
836 by Brian Aker
Fixed session call from function to method.
244
    session->my_ok();				// Tell client we are alive
1 by brian
clean slate
245
    break;
246
  case COM_SLEEP:
247
  case COM_CONNECT:				// Impossible here
248
  case COM_END:
249
  default:
250
    my_message(ER_UNKNOWN_COM_ERROR, ER(ER_UNKNOWN_COM_ERROR), MYF(0));
251
    break;
252
  }
253
254
  /* If commit fails, we should be able to reset the OK status. */
520.1.22 by Brian Aker
Second pass of thd cleanup
255
  session->main_da.can_overwrite_status= true;
1273.1.2 by Jay Pipes
This patch does not change any algorithms or code paths,
256
  TransactionServices &transaction_services= TransactionServices::singleton();
1405.3.5 by Jay Pipes
TransactionServices method names now meet code style guidelines.
257
  transaction_services.autocommitOrRollback(session, session->is_error());
520.1.22 by Brian Aker
Second pass of thd cleanup
258
  session->main_da.can_overwrite_status= false;
1 by brian
clean slate
259
520.1.22 by Brian Aker
Second pass of thd cleanup
260
  session->transaction.stmt.reset();
1 by brian
clean slate
261
262
263
  /* report error issued during command execution */
520.1.22 by Brian Aker
Second pass of thd cleanup
264
  if (session->killed_errno())
265
  {
266
    if (! session->main_da.is_set())
267
      session->send_kill_message();
268
  }
269
  if (session->killed == Session::KILL_QUERY || session->killed == Session::KILL_BAD_DATA)
270
  {
271
    session->killed= Session::NOT_KILLED;
1689.2.26 by Brian Aker
More encapsulation of the thread var.
272
    session->setAbort(false);
520.1.22 by Brian Aker
Second pass of thd cleanup
273
  }
274
971.3.12 by Eric Day
Started abstracting Protocol, removed init_connect, init_file.
275
  /* Can not be true, but do not take chances in production. */
276
  assert(! session->main_da.is_sent);
277
278
  switch (session->main_da.status())
279
  {
280
  case Diagnostics_area::DA_ERROR:
281
    /* The query failed, send error to log and abort bootstrap. */
971.6.1 by Eric Day
Renamed Protocol to Client, cleaned up some unnecessary methods along the way.
282
    session->client->sendError(session->main_da.sql_errno(),
283
                               session->main_da.message());
971.3.12 by Eric Day
Started abstracting Protocol, removed init_connect, init_file.
284
    break;
285
286
  case Diagnostics_area::DA_EOF:
971.6.1 by Eric Day
Renamed Protocol to Client, cleaned up some unnecessary methods along the way.
287
    session->client->sendEOF();
971.3.12 by Eric Day
Started abstracting Protocol, removed init_connect, init_file.
288
    break;
289
290
  case Diagnostics_area::DA_OK:
971.6.1 by Eric Day
Renamed Protocol to Client, cleaned up some unnecessary methods along the way.
291
    session->client->sendOK();
971.3.12 by Eric Day
Started abstracting Protocol, removed init_connect, init_file.
292
    break;
293
294
  case Diagnostics_area::DA_DISABLED:
295
    break;
296
297
  case Diagnostics_area::DA_EMPTY:
298
  default:
971.6.1 by Eric Day
Renamed Protocol to Client, cleaned up some unnecessary methods along the way.
299
    session->client->sendOK();
971.3.12 by Eric Day
Started abstracting Protocol, removed init_connect, init_file.
300
    break;
301
  }
302
303
  session->main_da.is_sent= true;
520.1.22 by Brian Aker
Second pass of thd cleanup
304
305
  session->set_proc_info("closing tables");
1 by brian
clean slate
306
  /* Free tables */
1039.1.16 by Brian Aker
A lot of little cleanups (most based off lcov)
307
  session->close_thread_tables();
520.1.22 by Brian Aker
Second pass of thd cleanup
308
1130.1.16 by Monty Taylor
Fixed naming issue.
309
  plugin::Logging::postDo(session);
520.1.22 by Brian Aker
Second pass of thd cleanup
310
961.1.4 by Brian Aker
Remove another lock for processlist.
311
  /* Store temp state for processlist */
520.1.22 by Brian Aker
Second pass of thd cleanup
312
  session->set_proc_info("cleaning up");
1126.10.2 by Padraig O'Sullivan
Added hooks into the command start and query start dtrace probes.
313
  session->command= COM_SLEEP;
1003.1.13 by Brian Aker
Memset should be used for init (I seconded guessed myself in a patch about
314
  memset(session->process_list_info, 0, PROCESS_LIST_WIDTH);
1280.3.11 by Padraig O'Sullivan
Changed the query member of Session to be std::string
315
  session->query.clear();
961.1.4 by Brian Aker
Remove another lock for processlist.
316
317
  session->set_proc_info(NULL);
1487 by Brian Aker
More updates for memory::Root
318
  session->mem_root->free_root(MYF(memory::KEEP_PREALLOC));
1126.10.2 by Padraig O'Sullivan
Added hooks into the command start and query start dtrace probes.
319
320
  if (DRIZZLE_QUERY_DONE_ENABLED() || DRIZZLE_COMMAND_DONE_ENABLED())
321
  {
322
    if (command == COM_QUERY)
323
    {
1126.10.21 by Padraig O'Sullivan
Whoops, simple fix for a build warning that happens if the build is not
324
      DRIZZLE_QUERY_DONE(session->is_error());
1126.10.2 by Padraig O'Sullivan
Added hooks into the command start and query start dtrace probes.
325
    }
1126.10.21 by Padraig O'Sullivan
Whoops, simple fix for a build warning that happens if the build is not
326
    DRIZZLE_COMMAND_DONE(session->is_error());
1126.10.2 by Padraig O'Sullivan
Added hooks into the command start and query start dtrace probes.
327
  }
328
329
  return error;
1 by brian
clean slate
330
}
331
332
333
/**
327.2.4 by Brian Aker
Refactoring table.h
334
  Create a TableList object for an INFORMATION_SCHEMA table.
1 by brian
clean slate
335
336
    This function is used in the parser to convert a SHOW or DESCRIBE
337
    table_name command to a SELECT from INFORMATION_SCHEMA.
846 by Brian Aker
Removing on typedeffed class.
338
    It prepares a Select_Lex and a TableList object to represent the
1 by brian
clean slate
339
    given command as a SELECT parse tree.
340
1079.2.9 by Padraig O'Sullivan
Removed the dependency on knowing the position of an I_S table in the
341
  @param session           thread handle
342
  @param lex               current lex
343
  @param table_ident       table alias if it's used
344
  @param schema_table_name the name of the INFORMATION_SCHEMA table to be
345
                           created
1 by brian
clean slate
346
347
  @note
348
    Due to the way this function works with memory and LEX it cannot
349
    be used outside the parser (parse tree transformations outside
350
    the parser break PS and SP).
351
352
  @retval
353
    0                 success
354
  @retval
355
    1                 out of memory or SHOW commands are not allowed
356
                      in this version of the server.
357
*/
1273.13.38 by Brian Aker
Add in new show work.
358
static bool _schema_select(Session *session, Select_Lex *sel,
359
                           const string& schema_table_name)
360
{
361
  LEX_STRING db, table;
362
  /*
363
     We have to make non const db_name & table_name
364
     because of lower_case_table_names
365
  */
366
  session->make_lex_string(&db, "data_dictionary", sizeof("data_dictionary"), false);
367
  session->make_lex_string(&table, schema_table_name, false);
368
369
  if (! sel->add_table_to_list(session, new Table_ident(db, table),
370
                               NULL, 0, TL_READ))
371
  {
372
    return true;
373
  }
374
  return false;
375
}
376
377
int prepare_new_schema_table(Session *session, LEX *lex,
378
                             const string& schema_table_name)
379
{
380
  Select_Lex *schema_select_lex= NULL;
381
382
  Select_Lex *select_lex= lex->current_select;
383
  assert(select_lex);
384
  if (_schema_select(session, select_lex, schema_table_name))
385
  {
386
    return(1);
387
  }
388
  TableList *table_list= (TableList*) select_lex->table_list.first;
389
  assert(table_list);
390
  table_list->schema_select_lex= schema_select_lex;
391
392
  return 0;
393
}
1 by brian
clean slate
394
395
/**
520.1.22 by Brian Aker
Second pass of thd cleanup
396
  Execute command saved in session and lex->sql_command.
1 by brian
clean slate
397
398
    Before every operation that can request a write lock for a table
399
    wait if a global read lock exists. However do not wait if this
400
    thread has locked tables already. No new locks can be requested
401
    until the other locks are released. The thread that requests the
402
    global read lock waits for write locked tables to become unlocked.
403
404
    Note that wait_if_global_read_lock() sets a protection against a new
405
    global read lock when it succeeds. This needs to be released by
406
    start_waiting_global_read_lock() after the operation.
407
520.1.22 by Brian Aker
Second pass of thd cleanup
408
  @param session                       Thread handle
1 by brian
clean slate
409
410
  @todo
411
    - Invalidate the table in the query cache if something changed
412
    after unlocking when changes become visible.
413
    TODO: this is workaround. right way will be move invalidating in
414
    the unlock procedure.
415
    - TODO: use check_change_password()
416
    - JOIN is not supported yet. TODO
417
    - SUSPEND and FOR MIGRATE are not supported yet. TODO
418
419
  @retval
55 by brian
Update for using real bool types.
420
    false       OK
1 by brian
clean slate
421
  @retval
55 by brian
Update for using real bool types.
422
    true        Error
1 by brian
clean slate
423
*/
424
1085.1.2 by Monty Taylor
Fixed -Wmissing-declarations
425
static int
520.1.22 by Brian Aker
Second pass of thd cleanup
426
mysql_execute_command(Session *session)
1 by brian
clean slate
427
{
1100.3.68 by Padraig O'Sullivan
Changed the type of res in mysql_execute_command() to bool instead of int
428
  bool res= false;
520.1.22 by Brian Aker
Second pass of thd cleanup
429
  LEX  *lex= session->lex;
846 by Brian Aker
Removing on typedeffed class.
430
  /* first Select_Lex (have special meaning for many of non-SELECTcommands) */
431
  Select_Lex *select_lex= &lex->select_lex;
1 by brian
clean slate
432
  /* list of all tables in query */
327.2.4 by Brian Aker
Refactoring table.h
433
  TableList *all_tables;
998 by Brian Aker
Patch on show processlist from davi@apache.org
434
  /* A peek into the query string */
1280.3.11 by Padraig O'Sullivan
Changed the query member of Session to be std::string
435
  size_t proc_info_len= session->query.length() > PROCESS_LIST_WIDTH ?
436
                        PROCESS_LIST_WIDTH : session->query.length();
998 by Brian Aker
Patch on show processlist from davi@apache.org
437
1280.3.11 by Padraig O'Sullivan
Changed the query member of Session to be std::string
438
  memcpy(session->process_list_info, session->query.c_str(), proc_info_len);
998 by Brian Aker
Patch on show processlist from davi@apache.org
439
  session->process_list_info[proc_info_len]= '\0';
1 by brian
clean slate
440
441
  /*
846 by Brian Aker
Removing on typedeffed class.
442
    In many cases first table of main Select_Lex have special meaning =>
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
443
    check that it is first table in global list and relink it first in
1 by brian
clean slate
444
    queries_tables list if it is necessary (we need such relinking only
445
    for queries with subqueries in select list, in this case tables of
446
    subqueries will go to global list first)
447
846 by Brian Aker
Removing on typedeffed class.
448
    all_tables will differ from first_table only if most upper Select_Lex
1 by brian
clean slate
449
    do not contain tables.
450
451
    Because of above in place where should be at least one table in most
846 by Brian Aker
Removing on typedeffed class.
452
    outer Select_Lex we have following check:
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
453
    assert(first_table == all_tables);
454
    assert(first_table == all_tables && first_table != 0);
1 by brian
clean slate
455
  */
456
  lex->first_lists_tables_same();
457
  /* should be assigned after making first tables same */
458
  all_tables= lex->query_tables;
459
  /* set context for commands which do not use setup_tables */
460
  select_lex->
327.2.4 by Brian Aker
Refactoring table.h
461
    context.resolve_in_table_list_only((TableList*)select_lex->
1 by brian
clean slate
462
                                       table_list.first);
463
464
  /*
465
    Reset warning count for each query that uses tables
466
    A better approach would be to reset this for any commands
467
    that is not a SHOW command or a select that only access local
468
    variables, but for now this is probably good enough.
469
    Don't reset warnings when executing a stored routine.
470
  */
1100.3.63 by Padraig O'Sullivan
Extracted the ALTER TABLE command into its own class and implementation
471
  if (all_tables || ! lex->is_single_level_stmt())
1100.3.66 by Padraig O'Sullivan
Extracted the last commands....Finally removed that gigantic switch
472
  {
520.1.22 by Brian Aker
Second pass of thd cleanup
473
    drizzle_reset_errors(session, 0);
1100.3.66 by Padraig O'Sullivan
Extracted the last commands....Finally removed that gigantic switch
474
  }
1 by brian
clean slate
475
1273.1.13 by Jay Pipes
Style cleanup around TransactionContext::modified_non_trans_table and dead code removal
476
  assert(session->transaction.stmt.hasModifiedNonTransData() == false);
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
477
1100.3.66 by Padraig O'Sullivan
Extracted the last commands....Finally removed that gigantic switch
478
  /* now we are ready to execute the statement */
479
  res= lex->statement->execute();
520.1.22 by Brian Aker
Second pass of thd cleanup
480
  session->set_proc_info("query end");
1 by brian
clean slate
481
  /*
482
    The return value for ROW_COUNT() is "implementation dependent" if the
483
    statement is not DELETE, INSERT or UPDATE, but -1 is what JDBC and ODBC
484
    wants. We also keep the last value in case of SQLCOM_CALL or
485
    SQLCOM_EXECUTE.
486
  */
1100.3.49 by Padraig O'Sullivan
Extracted the KILL command into its own class and implementation files.
487
  if (! (sql_command_flags[lex->sql_command].test(CF_BIT_HAS_ROW_COUNT)))
488
  {
520.1.22 by Brian Aker
Second pass of thd cleanup
489
    session->row_count_func= -1;
1100.3.49 by Padraig O'Sullivan
Extracted the KILL command into its own class and implementation files.
490
  }
1 by brian
clean slate
491
1100.3.63 by Padraig O'Sullivan
Extracted the ALTER TABLE command into its own class and implementation
492
  return (res || session->is_error());
1 by brian
clean slate
493
}
520.1.22 by Brian Aker
Second pass of thd cleanup
494
bool execute_sqlcom_select(Session *session, TableList *all_tables)
1 by brian
clean slate
495
{
520.1.22 by Brian Aker
Second pass of thd cleanup
496
  LEX	*lex= session->lex;
1 by brian
clean slate
497
  select_result *result=lex->result;
873.1.9 by Jay Pipes
This patch fixes the following functions to properly error out
498
  bool res= false;
1 by brian
clean slate
499
  /* assign global limit variable if limit is not given */
500
  {
846 by Brian Aker
Removing on typedeffed class.
501
    Select_Lex *param= lex->unit.global_parameters;
1 by brian
clean slate
502
    if (!param->explicit_limit)
503
      param->select_limit=
520.1.22 by Brian Aker
Second pass of thd cleanup
504
        new Item_int((uint64_t) session->variables.select_limit);
1 by brian
clean slate
505
  }
1415 by Brian Aker
Mass overhaul to use schema_identifier.
506
  if (not (res= session->openTablesLock(all_tables)))
1 by brian
clean slate
507
  {
508
    if (lex->describe)
509
    {
510
      /*
511
        We always use select_send for EXPLAIN, even if it's an EXPLAIN
512
        for SELECT ... INTO OUTFILE: a user application should be able
513
        to prepend EXPLAIN to any query and receive output for it,
514
        even if the query itself redirects the output.
515
      */
516
      if (!(result= new select_send()))
971.6.11 by Eric Day
Removed purecov messages.
517
        return true;
520.1.22 by Brian Aker
Second pass of thd cleanup
518
      session->send_explain_fields(result);
1240.7.1 by Padraig O'Sullivan
Created an ExplainPlan class in the optimizer namespace. All printing of an explain in drizzle goes
519
      optimizer::ExplainPlan planner;
520
      res= planner.explainUnion(session, &session->lex->unit, result);
1 by brian
clean slate
521
      if (lex->describe & DESCRIBE_EXTENDED)
522
      {
523
        char buff[1024];
205 by Brian Aker
uint32 -> uin32_t
524
        String str(buff,(uint32_t) sizeof(buff), system_charset_info);
1 by brian
clean slate
525
        str.length(0);
520.1.22 by Brian Aker
Second pass of thd cleanup
526
        session->lex->unit.print(&str, QT_ORDINARY);
1 by brian
clean slate
527
        str.append('\0');
520.1.22 by Brian Aker
Second pass of thd cleanup
528
        push_warning(session, DRIZZLE_ERROR::WARN_LEVEL_NOTE,
1 by brian
clean slate
529
                     ER_YES, str.ptr());
530
      }
531
      if (res)
532
        result->abort();
533
      else
534
        result->send_eof();
535
      delete result;
536
    }
537
    else
538
    {
539
      if (!result && !(result= new select_send()))
971.6.11 by Eric Day
Removed purecov messages.
540
        return true;
1643.6.1 by Djellel E. Difallah
Added hook points and the interface for the Query Cache plugin
541
542
      /* Init the Query Cache plugin */
1643.6.3 by Djellel E. Difallah
Refactoring of the QC Plugin's interface methods, adding mutual exclusion mechanism between sessions to cache a query, Store Meta inoformation of all the tables and select fields of the query
543
      plugin::QueryCache::prepareResultset(session); 
520.1.22 by Brian Aker
Second pass of thd cleanup
544
      res= handle_select(session, lex, result, 0);
1643.6.1 by Djellel E. Difallah
Added hook points and the interface for the Query Cache plugin
545
      /* Send the Resultset to the cache */
1643.6.3 by Djellel E. Difallah
Refactoring of the QC Plugin's interface methods, adding mutual exclusion mechanism between sessions to cache a query, Store Meta inoformation of all the tables and select fields of the query
546
      plugin::QueryCache::setResultset(session); 
1643.6.1 by Djellel E. Difallah
Added hook points and the interface for the Query Cache plugin
547
1 by brian
clean slate
548
      if (result != lex->result)
1643.6.3 by Djellel E. Difallah
Refactoring of the QC Plugin's interface methods, adding mutual exclusion mechanism between sessions to cache a query, Store Meta inoformation of all the tables and select fields of the query
549
        delete result;
1 by brian
clean slate
550
    }
551
  }
552
  return res;
553
}
554
555
556
#define MY_YACC_INIT 1000			// Start with big alloc
557
#define MY_YACC_MAX  32000			// Because of 'short'
558
559
bool my_yyoverflow(short **yyss, YYSTYPE **yyvs, ulong *yystacksize)
560
{
520.1.22 by Brian Aker
Second pass of thd cleanup
561
  LEX	*lex= current_session->lex;
1 by brian
clean slate
562
  ulong old_info=0;
438.1.13 by Brian Aker
uint cleanup.
563
  if ((uint32_t) *yystacksize >= MY_YACC_MAX)
1 by brian
clean slate
564
    return 1;
565
  if (!lex->yacc_yyvs)
566
    old_info= *yystacksize;
567
  *yystacksize= set_zone((*yystacksize)*2,MY_YACC_INIT,MY_YACC_MAX);
656.1.46 by Monty Taylor
More malloc return cleanups.
568
  unsigned char *tmpptr= NULL;
569
  if (!(tmpptr= (unsigned char *)realloc(lex->yacc_yyvs,
570
                                         *yystacksize* sizeof(**yyvs))))
571
      return 1;
572
  lex->yacc_yyvs= tmpptr;
573
  tmpptr= NULL;
574
  if (!(tmpptr= (unsigned char*)realloc(lex->yacc_yyss,
575
                                        *yystacksize* sizeof(**yyss))))
576
      return 1;
577
  lex->yacc_yyss= tmpptr;
1 by brian
clean slate
578
  if (old_info)
579
  {						// Copy old info from stack
212.6.6 by Mats Kindahl
Removing redundant use of casts in drizzled/ for memcmp(), memcpy(), memset(), and memmove().
580
    memcpy(lex->yacc_yyss, *yyss, old_info*sizeof(**yyss));
581
    memcpy(lex->yacc_yyvs, *yyvs, old_info*sizeof(**yyvs));
1 by brian
clean slate
582
  }
583
  *yyss=(short*) lex->yacc_yyss;
584
  *yyvs=(YYSTYPE*) lex->yacc_yyvs;
585
  return 0;
586
}
587
588
589
void
590
mysql_init_select(LEX *lex)
591
{
846 by Brian Aker
Removing on typedeffed class.
592
  Select_Lex *select_lex= lex->current_select;
1 by brian
clean slate
593
  select_lex->init_select();
594
  lex->wild= 0;
595
  if (select_lex == &lex->select_lex)
596
  {
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
597
    assert(lex->result == 0);
1 by brian
clean slate
598
    lex->exchange= 0;
599
  }
600
}
601
602
603
bool
604
mysql_new_select(LEX *lex, bool move_down)
605
{
846 by Brian Aker
Removing on typedeffed class.
606
  Select_Lex *select_lex;
520.1.22 by Brian Aker
Second pass of thd cleanup
607
  Session *session= lex->session;
1 by brian
clean slate
608
846 by Brian Aker
Removing on typedeffed class.
609
  if (!(select_lex= new (session->mem_root) Select_Lex()))
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
610
    return(1);
520.1.22 by Brian Aker
Second pass of thd cleanup
611
  select_lex->select_number= ++session->select_number;
1 by brian
clean slate
612
  select_lex->parent_lex= lex; /* Used in init_query. */
613
  select_lex->init_query();
614
  select_lex->init_select();
615
  lex->nest_level++;
616
  if (lex->nest_level > (int) MAX_SELECT_NESTING)
617
  {
618
    my_error(ER_TOO_HIGH_LEVEL_OF_NESTING_FOR_SELECT,MYF(0),MAX_SELECT_NESTING);
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
619
    return(1);
1 by brian
clean slate
620
  }
621
  select_lex->nest_level= lex->nest_level;
622
  if (move_down)
623
  {
848 by Brian Aker
typdef class removal (just... use the name of the class).
624
    Select_Lex_Unit *unit;
1 by brian
clean slate
625
    /* first select_lex of subselect or derived table */
848 by Brian Aker
typdef class removal (just... use the name of the class).
626
    if (!(unit= new (session->mem_root) Select_Lex_Unit()))
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
627
      return(1);
1 by brian
clean slate
628
629
    unit->init_query();
630
    unit->init_select();
520.1.22 by Brian Aker
Second pass of thd cleanup
631
    unit->session= session;
1 by brian
clean slate
632
    unit->include_down(lex->current_select);
633
    unit->link_next= 0;
634
    unit->link_prev= 0;
635
    unit->return_to= lex->current_select;
636
    select_lex->include_down(unit);
637
    /*
638
      By default we assume that it is usual subselect and we have outer name
639
      resolution context, if no we will assign it to 0 later
640
    */
641
    select_lex->context.outer_context= &select_lex->outer_select()->context;
642
  }
643
  else
644
  {
645
    if (lex->current_select->order_list.first && !lex->current_select->braces)
646
    {
327.2.3 by Brian Aker
Refactoring of class Table
647
      my_error(ER_WRONG_USAGE, MYF(0), "UNION", "order_st BY");
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
648
      return(1);
1 by brian
clean slate
649
    }
650
    select_lex->include_neighbour(lex->current_select);
848 by Brian Aker
typdef class removal (just... use the name of the class).
651
    Select_Lex_Unit *unit= select_lex->master_unit();
520.1.22 by Brian Aker
Second pass of thd cleanup
652
    if (!unit->fake_select_lex && unit->add_fake_select_lex(lex->session))
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
653
      return(1);
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
654
    select_lex->context.outer_context=
1 by brian
clean slate
655
                unit->first_select()->context.outer_context;
656
  }
657
658
  select_lex->master_unit()->global_parameters= select_lex;
847 by Brian Aker
More typdef class removal.
659
  select_lex->include_global((Select_Lex_Node**)&lex->all_selects_list);
1 by brian
clean slate
660
  lex->current_select= select_lex;
661
  /*
662
    in subquery is SELECT query and we allow resolution of names in SELECT
663
    list
664
  */
55 by brian
Update for using real bool types.
665
  select_lex->context.resolve_in_select_list= true;
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
666
  return(0);
1 by brian
clean slate
667
}
668
669
/**
670
  Create a select to return the same output as 'SELECT @@var_name'.
671
672
  Used for SHOW COUNT(*) [ WARNINGS | ERROR].
673
674
  This will crash with a core dump if the variable doesn't exists.
675
676
  @param var_name		Variable name
677
*/
678
679
void create_select_for_variable(const char *var_name)
680
{
520.1.22 by Brian Aker
Second pass of thd cleanup
681
  Session *session;
1 by brian
clean slate
682
  LEX *lex;
683
  LEX_STRING tmp, null_lex_string;
684
  Item *var;
673.2.1 by Toru Maesaka
First pass of replacing MySQL's strxmov with libc alternatives
685
  char buff[MAX_SYS_VAR_LENGTH*2+4+8];
686
  char *end= buff;
1 by brian
clean slate
687
520.1.22 by Brian Aker
Second pass of thd cleanup
688
  session= current_session;
689
  lex= session->lex;
1 by brian
clean slate
690
  mysql_init_select(lex);
691
  lex->sql_command= SQLCOM_SELECT;
692
  tmp.str= (char*) var_name;
693
  tmp.length=strlen(var_name);
212.6.6 by Mats Kindahl
Removing redundant use of casts in drizzled/ for memcmp(), memcpy(), memset(), and memmove().
694
  memset(&null_lex_string.str, 0, sizeof(null_lex_string));
1 by brian
clean slate
695
  /*
696
    We set the name of Item to @@session.var_name because that then is used
697
    as the column name in the output.
698
  */
520.1.22 by Brian Aker
Second pass of thd cleanup
699
  if ((var= get_system_var(session, OPT_SESSION, tmp, null_lex_string)))
1 by brian
clean slate
700
  {
1366.1.10 by Siddharth Prakash Singh
sprintf->snprintf in drizzled/sql_parse.cc
701
    end+= snprintf(buff, sizeof(buff), "@@session.%s", var_name);
1 by brian
clean slate
702
    var->set_name(buff, end-buff, system_charset_info);
838 by Brian Aker
More class adoption/method
703
    session->add_item_to_list(var);
1 by brian
clean slate
704
  }
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
705
  return;
1 by brian
clean slate
706
}
707
708
709
/**
710
  Parse a query.
711
520.1.22 by Brian Aker
Second pass of thd cleanup
712
  @param       session     Current thread
1 by brian
clean slate
713
  @param       inBuf   Begining of the query text
714
  @param       length  Length of the query text
715
*/
716
1280.3.17 by Padraig O'Sullivan
Merged from Monty
717
void mysql_parse(Session *session, const char *inBuf, uint32_t length)
1 by brian
clean slate
718
{
1625.2.1 by Joe Daly
initial user stats impl
719
  uint64_t start_time= my_getsystime();
520.1.22 by Brian Aker
Second pass of thd cleanup
720
  lex_start(session);
735 by Brian Aker
Refactor session.
721
  session->reset_for_next_command();
1643.6.3 by Djellel E. Difallah
Refactoring of the QC Plugin's interface methods, adding mutual exclusion mechanism between sessions to cache a query, Store Meta inoformation of all the tables and select fields of the query
722
  /* Check if the Query is Cached if and return true if yes
723
   * TODO the plugin has to make sure that the query is cacheble
724
   * by setting the query_safe_cache param to TRUE
725
   */
1643.6.4 by Djellel E. Difallah
Added data dictionary view 'Query_cache_entries' to list current cached queries. Added a UDF print_query_cache_meta(key) to display a text representation of the metadata
726
  bool res= true;
727
  if (plugin::QueryCache::isCached(session))
1280.3.8 by Padraig O'Sullivan
Removed an obsolete comment related to the query cache that was confusing.
728
  {
1643.6.4 by Djellel E. Difallah
Added data dictionary view 'Query_cache_entries' to list current cached queries. Added a UDF print_query_cache_meta(key) to display a text representation of the metadata
729
    res= plugin::QueryCache::sendCachedResultset(session);
730
  }
731
  if (not res)
1643.6.13 by Djellel E. Difallah
adding tests
732
  {
1643.6.4 by Djellel E. Difallah
Added data dictionary view 'Query_cache_entries' to list current cached queries. Added a UDF print_query_cache_meta(key) to display a text representation of the metadata
733
    return;
1643.6.13 by Djellel E. Difallah
adding tests
734
  }
1643.6.4 by Djellel E. Difallah
Added data dictionary view 'Query_cache_entries' to list current cached queries. Added a UDF print_query_cache_meta(key) to display a text representation of the metadata
735
  LEX *lex= session->lex;
736
  Lex_input_stream lip(session, inBuf, length);
737
  bool err= parse_sql(session, &lip);
738
  if (!err)
739
  {
740
    {
741
      if (! session->is_error())
742
      {
743
        DRIZZLE_QUERY_EXEC_START(session->query.c_str(),
744
                                 session->thread_id,
745
                                 const_cast<const char *>(session->db.empty() ? "" : session->db.c_str()));
746
        // Implement Views here --Brian
747
        /* Actually execute the query */
748
        try 
749
        {
750
          mysql_execute_command(session);
751
        }
752
        catch (...)
753
        {
754
          // Just try to catch any random failures that could have come
755
          // during execution.
756
        }
757
        DRIZZLE_QUERY_EXEC_DONE(0);
758
      }
759
    }
760
  }
761
  else
762
  {
763
    assert(session->is_error());
764
  }
765
  lex->unit.cleanup();
766
  session->set_proc_info("freeing items");
767
  session->end_statement();
768
  session->cleanup_after_query();
1625.2.1 by Joe Daly
initial user stats impl
769
  session->status_var.execution_time_nsec+= my_getsystime() - start_time;
1 by brian
clean slate
770
}
771
772
773
774
/**
775
  Store field definition for create.
776
777
  @return
778
    Return 0 if ok
779
*/
780
520.1.22 by Brian Aker
Second pass of thd cleanup
781
bool add_field_to_list(Session *session, LEX_STRING *field_name, enum_field_types type,
1 by brian
clean slate
782
		       char *length, char *decimals,
438.1.13 by Brian Aker
uint cleanup.
783
		       uint32_t type_modifier,
1 by brian
clean slate
784
                       enum column_format_type column_format,
785
		       Item *default_value, Item *on_update_value,
786
                       LEX_STRING *comment,
787
		       char *change,
998.1.2 by Brian Aker
First pass on removing virt columns
788
                       List<String> *interval_list, const CHARSET_INFO * const cs)
1 by brian
clean slate
789
{
1052.2.3 by Nathan Williams
No actual code changes. Changed Create_field to CreateField to be consistent with coding standards.
790
  register CreateField *new_field;
520.1.22 by Brian Aker
Second pass of thd cleanup
791
  LEX  *lex= session->lex;
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
792
  statement::AlterTable *statement= (statement::AlterTable *)lex->statement;
1 by brian
clean slate
793
794
  if (check_identifier_name(field_name, ER_TOO_LONG_IDENT))
1135 by Brian Aker
Merge of Lex -> Statement refactoring
795
    return true;
1 by brian
clean slate
796
797
  if (type_modifier & PRI_KEY_FLAG)
798
  {
799
    Key *key;
800
    lex->col_list.push_back(new Key_part_spec(*field_name, 0));
801
    key= new Key(Key::PRIMARY, null_lex_str,
802
                      &default_key_create_info,
803
                      0, lex->col_list);
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
804
    statement->alter_info.key_list.push_back(key);
1 by brian
clean slate
805
    lex->col_list.empty();
806
  }
807
  if (type_modifier & (UNIQUE_FLAG | UNIQUE_KEY_FLAG))
808
  {
809
    Key *key;
810
    lex->col_list.push_back(new Key_part_spec(*field_name, 0));
811
    key= new Key(Key::UNIQUE, null_lex_str,
812
                 &default_key_create_info, 0,
813
                 lex->col_list);
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
814
    statement->alter_info.key_list.push_back(key);
1 by brian
clean slate
815
    lex->col_list.empty();
816
  }
817
818
  if (default_value)
819
  {
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
820
    /*
1 by brian
clean slate
821
      Default value should be literal => basic constants =>
822
      no need fix_fields()
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
823
824
      We allow only one function as part of default value -
1 by brian
clean slate
825
      NOW() as default for TIMESTAMP type.
826
    */
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
827
    if (default_value->type() == Item::FUNC_ITEM &&
1 by brian
clean slate
828
        !(((Item_func*)default_value)->functype() == Item_func::NOW_FUNC &&
212.2.2 by Patrick Galbraith
Renamed FIELD_TYPE to DRIZZLE_TYPE
829
         type == DRIZZLE_TYPE_TIMESTAMP))
1 by brian
clean slate
830
    {
831
      my_error(ER_INVALID_DEFAULT, MYF(0), field_name->str);
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
832
      return true;
1 by brian
clean slate
833
    }
834
    else if (default_value->type() == Item::NULL_ITEM)
835
    {
836
      default_value= 0;
837
      if ((type_modifier & (NOT_NULL_FLAG | AUTO_INCREMENT_FLAG)) ==
838
	  NOT_NULL_FLAG)
839
      {
840
	my_error(ER_INVALID_DEFAULT, MYF(0), field_name->str);
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
841
	return true;
1 by brian
clean slate
842
      }
843
    }
844
    else if (type_modifier & AUTO_INCREMENT_FLAG)
845
    {
846
      my_error(ER_INVALID_DEFAULT, MYF(0), field_name->str);
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
847
      return true;
1 by brian
clean slate
848
    }
849
  }
850
212.2.2 by Patrick Galbraith
Renamed FIELD_TYPE to DRIZZLE_TYPE
851
  if (on_update_value && type != DRIZZLE_TYPE_TIMESTAMP)
1 by brian
clean slate
852
  {
853
    my_error(ER_INVALID_ON_UPDATE, MYF(0), field_name->str);
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
854
    return true;
1 by brian
clean slate
855
  }
856
1052.2.3 by Nathan Williams
No actual code changes. Changed Create_field to CreateField to be consistent with coding standards.
857
  if (!(new_field= new CreateField()) ||
520.1.22 by Brian Aker
Second pass of thd cleanup
858
      new_field->init(session, field_name->str, type, length, decimals, type_modifier,
1 by brian
clean slate
859
                      default_value, on_update_value, comment, change,
998.1.2 by Brian Aker
First pass on removing virt columns
860
                      interval_list, cs, 0, column_format))
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
861
    return true;
1 by brian
clean slate
862
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
863
  statement->alter_info.create_list.push_back(new_field);
1 by brian
clean slate
864
  lex->last_field=new_field;
1128.2.4 by Brian Aker
AlterInfo refactor back to class.
865
866
  return false;
1 by brian
clean slate
867
}
868
869
870
/** Store position for column in ALTER TABLE .. ADD column. */
871
872
void store_position_for_column(const char *name)
873
{
520.1.22 by Brian Aker
Second pass of thd cleanup
874
  current_session->lex->last_field->after=const_cast<char*> (name);
1 by brian
clean slate
875
}
876
877
/**
878
  Add a table to list of used tables.
879
880
  @param table		Table to add
881
  @param alias		alias for table (or null if no alias)
882
  @param table_options	A set of the following bits:
883
                         - TL_OPTION_UPDATING : Table will be updated
884
                         - TL_OPTION_FORCE_INDEX : Force usage of index
885
                         - TL_OPTION_ALIAS : an alias in multi table DELETE
886
  @param lock_type	How table should be locked
887
  @param use_index	List of indexed used in USE INDEX
888
  @param ignore_index	List of indexed used in IGNORE INDEX
889
890
  @retval
891
      0		Error
892
  @retval
327.2.4 by Brian Aker
Refactoring table.h
893
    \#	Pointer to TableList element added to the total table list
1 by brian
clean slate
894
*/
895
846 by Brian Aker
Removing on typedeffed class.
896
TableList *Select_Lex::add_table_to_list(Session *session,
1 by brian
clean slate
897
					     Table_ident *table,
898
					     LEX_STRING *alias,
202 by Brian Aker
Cleanup sql_lex to modern types.
899
					     uint32_t table_options,
1 by brian
clean slate
900
					     thr_lock_type lock_type,
901
					     List<Index_hint> *index_hints_arg,
902
                                             LEX_STRING *option)
903
{
327.2.4 by Brian Aker
Refactoring table.h
904
  register TableList *ptr;
905
  TableList *previous_table_ref; /* The table preceding the current one. */
1 by brian
clean slate
906
  char *alias_str;
520.1.22 by Brian Aker
Second pass of thd cleanup
907
  LEX *lex= session->lex;
1 by brian
clean slate
908
909
  if (!table)
1054.1.5 by Brian Aker
Formatting/remove dead variables.
910
    return NULL;				// End of memory
1 by brian
clean slate
911
  alias_str= alias ? alias->str : table->table.str;
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
912
  if (!test(table_options & TL_OPTION_ALIAS) &&
1 by brian
clean slate
913
      check_table_name(table->table.str, table->table.length))
914
  {
915
    my_error(ER_WRONG_TABLE_NAME, MYF(0), table->table.str);
1054.1.5 by Brian Aker
Formatting/remove dead variables.
916
    return NULL;
1 by brian
clean slate
917
  }
918
1415 by Brian Aker
Mass overhaul to use schema_identifier.
919
  if (table->is_derived_table() == false && table->db.str)
1 by brian
clean slate
920
  {
1415 by Brian Aker
Mass overhaul to use schema_identifier.
921
    my_casedn_str(files_charset_info, table->db.str);
922
1471.2.1 by Monty Taylor
There's a bug here. Passing in the length causes std::string to believe the
923
    SchemaIdentifier schema_identifier(string(table->db.str));
1578.4.11 by Brian Aker
PAss through the code removing current_session
924
    if (not check_db_name(session, schema_identifier))
1415 by Brian Aker
Mass overhaul to use schema_identifier.
925
    {
926
927
      my_error(ER_WRONG_DB_NAME, MYF(0), table->db.str);
928
      return NULL;
929
    }
1 by brian
clean slate
930
  }
931
932
  if (!alias)					/* Alias is case sensitive */
933
  {
934
    if (table->sel)
935
    {
936
      my_message(ER_DERIVED_MUST_HAVE_ALIAS,
937
                 ER(ER_DERIVED_MUST_HAVE_ALIAS), MYF(0));
1054.1.5 by Brian Aker
Formatting/remove dead variables.
938
      return NULL;
1 by brian
clean slate
939
    }
520.1.22 by Brian Aker
Second pass of thd cleanup
940
    if (!(alias_str= (char*) session->memdup(alias_str,table->table.length+1)))
1054.1.5 by Brian Aker
Formatting/remove dead variables.
941
      return NULL;
1 by brian
clean slate
942
  }
520.1.22 by Brian Aker
Second pass of thd cleanup
943
  if (!(ptr = (TableList *) session->calloc(sizeof(TableList))))
971.6.11 by Eric Day
Removed purecov messages.
944
    return NULL;
1672.3.5 by Brian Aker
This replaces the allocation we do for insert/update.
945
1 by brian
clean slate
946
  if (table->db.str)
947
  {
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
948
    ptr->setIsFqtn(true);
1 by brian
clean slate
949
    ptr->db= table->db.str;
950
    ptr->db_length= table->db.length;
951
  }
952
  else if (lex->copy_db_to(&ptr->db, &ptr->db_length))
1054.1.5 by Brian Aker
Formatting/remove dead variables.
953
    return NULL;
1 by brian
clean slate
954
  else
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
955
    ptr->setIsFqtn(false);
1 by brian
clean slate
956
957
  ptr->alias= alias_str;
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
958
  ptr->setIsAlias(alias ? true : false);
1039.1.5 by Brian Aker
Remove lower case filename bits (aka we just lock into the most compatible
959
  if (table->table.length)
1 by brian
clean slate
960
    table->table.length= my_casedn_str(files_charset_info, table->table.str);
961
  ptr->table_name=table->table.str;
962
  ptr->table_name_length=table->table.length;
963
  ptr->lock_type=   lock_type;
964
  ptr->force_index= test(table_options & TL_OPTION_FORCE_INDEX);
965
  ptr->ignore_leaves= test(table_options & TL_OPTION_IGNORE_LEAVES);
966
  ptr->derived=	    table->sel;
967
  ptr->select_lex=  lex->current_select;
968
  ptr->index_hints= index_hints_arg;
969
  ptr->option= option ? option->str : 0;
970
  /* check that used name is unique */
971
  if (lock_type != TL_IGNORE)
972
  {
327.2.4 by Brian Aker
Refactoring table.h
973
    TableList *first_table= (TableList*) table_list.first;
974
    for (TableList *tables= first_table ;
1 by brian
clean slate
975
	 tables ;
976
	 tables=tables->next_local)
977
    {
978
      if (!my_strcasecmp(table_alias_charset, alias_str, tables->alias) &&
1415 by Brian Aker
Mass overhaul to use schema_identifier.
979
	  !strcasecmp(ptr->db, tables->db))
1 by brian
clean slate
980
      {
971.6.11 by Eric Day
Removed purecov messages.
981
	my_error(ER_NONUNIQ_TABLE, MYF(0), alias_str);
982
	return NULL;
1 by brian
clean slate
983
      }
984
    }
985
  }
986
  /* Store the table reference preceding the current one. */
987
  if (table_list.elements > 0)
988
  {
989
    /*
327.2.4 by Brian Aker
Refactoring table.h
990
      table_list.next points to the last inserted TableList->next_local'
1 by brian
clean slate
991
      element
992
      We don't use the offsetof() macro here to avoid warnings from gcc
993
    */
327.2.4 by Brian Aker
Refactoring table.h
994
    previous_table_ref= (TableList*) ((char*) table_list.next -
1 by brian
clean slate
995
                                       ((char*) &(ptr->next_local) -
996
                                        (char*) ptr));
997
    /*
998
      Set next_name_resolution_table of the previous table reference to point
999
      to the current table reference. In effect the list
327.2.4 by Brian Aker
Refactoring table.h
1000
      TableList::next_name_resolution_table coincides with
1001
      TableList::next_local. Later this may be changed in
1 by brian
clean slate
1002
      store_top_level_join_columns() for NATURAL/USING joins.
1003
    */
1004
    previous_table_ref->next_name_resolution_table= ptr;
1005
  }
1006
1007
  /*
1008
    Link the current table reference in a local list (list for current select).
1009
    Notice that as a side effect here we set the next_local field of the
1010
    previous table reference to 'ptr'. Here we also add one element to the
1011
    list 'table_list'.
1012
  */
481 by Brian Aker
Remove all of uchar.
1013
  table_list.link_in_list((unsigned char*) ptr, (unsigned char**) &ptr->next_local);
1 by brian
clean slate
1014
  ptr->next_name_resolution_table= NULL;
1015
  /* Link table in global list (all used tables) */
1016
  lex->add_to_query_tables(ptr);
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1017
  return ptr;
1 by brian
clean slate
1018
}
1019
1020
1021
/**
1022
  Initialize a new table list for a nested join.
1023
327.2.4 by Brian Aker
Refactoring table.h
1024
    The function initializes a structure of the TableList type
1 by brian
clean slate
1025
    for a nested join. It sets up its nested join list as empty.
1026
    The created structure is added to the front of the current
846 by Brian Aker
Removing on typedeffed class.
1027
    join list in the Select_Lex object. Then the function
1 by brian
clean slate
1028
    changes the current nest level for joins to refer to the newly
1029
    created empty list after having saved the info on the old level
1030
    in the initialized structure.
1031
520.1.22 by Brian Aker
Second pass of thd cleanup
1032
  @param session         current thread
1 by brian
clean slate
1033
1034
  @retval
1035
    0   if success
1036
  @retval
1037
    1   otherwise
1038
*/
1039
846 by Brian Aker
Removing on typedeffed class.
1040
bool Select_Lex::init_nested_join(Session *session)
1 by brian
clean slate
1041
{
327.2.4 by Brian Aker
Refactoring table.h
1042
  TableList *ptr;
1043
  nested_join_st *nested_join;
1 by brian
clean slate
1044
520.1.22 by Brian Aker
Second pass of thd cleanup
1045
  if (!(ptr= (TableList*) session->calloc(ALIGN_SIZE(sizeof(TableList))+
327.2.4 by Brian Aker
Refactoring table.h
1046
                                       sizeof(nested_join_st))))
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1047
    return true;
1637.2.7 by Vijay Samuel
Merge encapsulate TableList-2.
1048
  ptr->setNestedJoin(((nested_join_st*) ((unsigned char*) ptr + ALIGN_SIZE(sizeof(TableList)))));
1049
  nested_join= ptr->getNestedJoin();
1 by brian
clean slate
1050
  join_list->push_front(ptr);
1637.2.7 by Vijay Samuel
Merge encapsulate TableList-2.
1051
  ptr->setEmbedding(embedding);
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
1052
  ptr->setJoinList(join_list);
1 by brian
clean slate
1053
  ptr->alias= (char*) "(nested_join)";
1054
  embedding= ptr;
1055
  join_list= &nested_join->join_list;
1056
  join_list->empty();
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1057
  return false;
1 by brian
clean slate
1058
}
1059
1060
1061
/**
1062
  End a nested join table list.
1063
1064
    The function returns to the previous join nest level.
1065
    If the current level contains only one member, the function
1066
    moves it one level up, eliminating the nest.
1067
520.1.22 by Brian Aker
Second pass of thd cleanup
1068
  @param session         current thread
1 by brian
clean slate
1069
1070
  @return
327.2.4 by Brian Aker
Refactoring table.h
1071
    - Pointer to TableList element added to the total table list, if success
1 by brian
clean slate
1072
    - 0, otherwise
1073
*/
1074
846 by Brian Aker
Removing on typedeffed class.
1075
TableList *Select_Lex::end_nested_join(Session *)
1 by brian
clean slate
1076
{
327.2.4 by Brian Aker
Refactoring table.h
1077
  TableList *ptr;
1078
  nested_join_st *nested_join;
1 by brian
clean slate
1079
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1080
  assert(embedding);
1 by brian
clean slate
1081
  ptr= embedding;
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
1082
  join_list= ptr->getJoinList();
1637.2.7 by Vijay Samuel
Merge encapsulate TableList-2.
1083
  embedding= ptr->getEmbedding();
1084
  nested_join= ptr->getNestedJoin();
1 by brian
clean slate
1085
  if (nested_join->join_list.elements == 1)
1086
  {
327.2.4 by Brian Aker
Refactoring table.h
1087
    TableList *embedded= nested_join->join_list.head();
1 by brian
clean slate
1088
    join_list->pop();
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
1089
    embedded->setJoinList(join_list);
1637.2.7 by Vijay Samuel
Merge encapsulate TableList-2.
1090
    embedded->setEmbedding(embedding);
1 by brian
clean slate
1091
    join_list->push_front(embedded);
1092
    ptr= embedded;
1093
  }
1094
  else if (nested_join->join_list.elements == 0)
1095
  {
1096
    join_list->pop();
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1097
    ptr= NULL;                                     // return value
1 by brian
clean slate
1098
  }
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1099
  return ptr;
1 by brian
clean slate
1100
}
1101
1102
1103
/**
1104
  Nest last join operation.
1105
1106
    The function nest last join operation as if it was enclosed in braces.
1107
520.1.22 by Brian Aker
Second pass of thd cleanup
1108
  @param session         current thread
1 by brian
clean slate
1109
1110
  @retval
1111
    0  Error
1112
  @retval
327.2.4 by Brian Aker
Refactoring table.h
1113
    \#  Pointer to TableList element created for the new nested join
1 by brian
clean slate
1114
*/
1115
846 by Brian Aker
Removing on typedeffed class.
1116
TableList *Select_Lex::nest_last_join(Session *session)
1 by brian
clean slate
1117
{
327.2.4 by Brian Aker
Refactoring table.h
1118
  TableList *ptr;
1119
  nested_join_st *nested_join;
1120
  List<TableList> *embedded_list;
1 by brian
clean slate
1121
520.1.22 by Brian Aker
Second pass of thd cleanup
1122
  if (!(ptr= (TableList*) session->calloc(ALIGN_SIZE(sizeof(TableList))+
1672.3.5 by Brian Aker
This replaces the allocation we do for insert/update.
1123
                                          sizeof(nested_join_st))))
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1124
    return NULL;
1637.2.7 by Vijay Samuel
Merge encapsulate TableList-2.
1125
  ptr->setNestedJoin(((nested_join_st*) ((unsigned char*) ptr + ALIGN_SIZE(sizeof(TableList)))));
1126
  nested_join= ptr->getNestedJoin();
1127
  ptr->setEmbedding(embedding);
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
1128
  ptr->setJoinList(join_list);
1 by brian
clean slate
1129
  ptr->alias= (char*) "(nest_last_join)";
1130
  embedded_list= &nested_join->join_list;
1131
  embedded_list->empty();
1132
438.1.13 by Brian Aker
uint cleanup.
1133
  for (uint32_t i=0; i < 2; i++)
1 by brian
clean slate
1134
  {
327.2.4 by Brian Aker
Refactoring table.h
1135
    TableList *table= join_list->pop();
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
1136
    table->setJoinList(embedded_list);
1637.2.7 by Vijay Samuel
Merge encapsulate TableList-2.
1137
    table->setEmbedding(ptr);
1 by brian
clean slate
1138
    embedded_list->push_back(table);
1139
    if (table->natural_join)
1140
    {
55 by brian
Update for using real bool types.
1141
      ptr->is_natural_join= true;
1 by brian
clean slate
1142
      /*
1143
        If this is a JOIN ... USING, move the list of joined fields to the
1144
        table reference that describes the join.
1145
      */
1146
      if (prev_join_using)
1147
        ptr->join_using_fields= prev_join_using;
1148
    }
1149
  }
1150
  join_list->push_front(ptr);
1151
  nested_join->used_tables= nested_join->not_null_tables= (table_map) 0;
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1152
  return ptr;
1 by brian
clean slate
1153
}
1154
1155
1156
/**
1157
  Add a table to the current join list.
1158
1159
    The function puts a table in front of the current join list
846 by Brian Aker
Removing on typedeffed class.
1160
    of Select_Lex object.
1 by brian
clean slate
1161
    Thus, joined tables are put into this list in the reverse order
1162
    (the most outer join operation follows first).
1163
1164
  @param table       the table to add
1165
1166
  @return
1167
    None
1168
*/
1169
846 by Brian Aker
Removing on typedeffed class.
1170
void Select_Lex::add_joined_table(TableList *table)
1 by brian
clean slate
1171
{
1172
  join_list->push_front(table);
1637.2.6 by Vijay Samuel
Merge encapsulate TableList-1.
1173
  table->setJoinList(join_list);
1637.2.7 by Vijay Samuel
Merge encapsulate TableList-2.
1174
  table->setEmbedding(embedding);
1 by brian
clean slate
1175
}
1176
1177
1178
/**
1179
  Convert a right join into equivalent left join.
1180
1181
    The function takes the current join list t[0],t[1] ... and
1182
    effectively converts it into the list t[1],t[0] ...
1183
    Although the outer_join flag for the new nested table contains
1184
    JOIN_TYPE_RIGHT, it will be handled as the inner table of a left join
1185
    operation.
1186
1187
  EXAMPLES
1188
  @verbatim
1189
    SELECT * FROM t1 RIGHT JOIN t2 ON on_expr =>
1190
      SELECT * FROM t2 LEFT JOIN t1 ON on_expr
1191
1192
    SELECT * FROM t1,t2 RIGHT JOIN t3 ON on_expr =>
1193
      SELECT * FROM t1,t3 LEFT JOIN t2 ON on_expr
1194
1195
    SELECT * FROM t1,t2 RIGHT JOIN (t3,t4) ON on_expr =>
1196
      SELECT * FROM t1,(t3,t4) LEFT JOIN t2 ON on_expr
1197
1198
    SELECT * FROM t1 LEFT JOIN t2 ON on_expr1 RIGHT JOIN t3  ON on_expr2 =>
1199
      SELECT * FROM t3 LEFT JOIN (t1 LEFT JOIN t2 ON on_expr2) ON on_expr1
1200
   @endverbatim
1201
520.1.22 by Brian Aker
Second pass of thd cleanup
1202
  @param session         current thread
1 by brian
clean slate
1203
1204
  @return
1205
    - Pointer to the table representing the inner table, if success
1206
    - 0, otherwise
1207
*/
1208
846 by Brian Aker
Removing on typedeffed class.
1209
TableList *Select_Lex::convert_right_join()
1 by brian
clean slate
1210
{
327.2.4 by Brian Aker
Refactoring table.h
1211
  TableList *tab2= join_list->pop();
1212
  TableList *tab1= join_list->pop();
1 by brian
clean slate
1213
1214
  join_list->push_front(tab2);
1215
  join_list->push_front(tab1);
1216
  tab1->outer_join|= JOIN_TYPE_RIGHT;
1217
1054.1.5 by Brian Aker
Formatting/remove dead variables.
1218
  return tab1;
1 by brian
clean slate
1219
}
1220
1221
/**
1222
  Set lock for all tables in current select level.
1223
1224
  @param lock_type			Lock to set for tables
1225
1226
  @note
1227
    If lock is a write lock, then tables->updating is set 1
1228
    This is to get tables_ok to know that the table is updated by the
1229
    query
1230
*/
1231
846 by Brian Aker
Removing on typedeffed class.
1232
void Select_Lex::set_lock_for_tables(thr_lock_type lock_type)
1 by brian
clean slate
1233
{
327.2.4 by Brian Aker
Refactoring table.h
1234
  for (TableList *tables= (TableList*) table_list.first;
1 by brian
clean slate
1235
       tables;
1236
       tables= tables->next_local)
1237
  {
1238
    tables->lock_type= lock_type;
1239
  }
1240
}
1241
1242
1243
/**
846 by Brian Aker
Removing on typedeffed class.
1244
  Create a fake Select_Lex for a unit.
1 by brian
clean slate
1245
846 by Brian Aker
Removing on typedeffed class.
1246
    The method create a fake Select_Lex object for a unit.
1 by brian
clean slate
1247
    This object is created for any union construct containing a union
1248
    operation and also for any single select union construct of the form
1249
    @verbatim
1273.2.9 by Stewart Smith
fix accidental mangling of comment: s/order_st BY/ORDER BY/. in sql_parse.cc
1250
    (SELECT ... ORDER BY order_list [LIMIT n]) ORDER BY ...
1 by brian
clean slate
1251
    @endvarbatim
1252
    or of the form
1253
    @varbatim
1273.2.9 by Stewart Smith
fix accidental mangling of comment: s/order_st BY/ORDER BY/. in sql_parse.cc
1254
    (SELECT ... ORDER BY LIMIT n) ORDER BY ...
1 by brian
clean slate
1255
    @endvarbatim
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
1256
520.1.22 by Brian Aker
Second pass of thd cleanup
1257
  @param session_arg		   thread handle
1 by brian
clean slate
1258
1259
  @note
1260
    The object is used to retrieve rows from the temporary table
1261
    where the result on the union is obtained.
1262
1263
  @retval
1264
    1     on failure to create the object
1265
  @retval
1266
    0     on success
1267
*/
1268
848 by Brian Aker
typdef class removal (just... use the name of the class).
1269
bool Select_Lex_Unit::add_fake_select_lex(Session *session_arg)
1 by brian
clean slate
1270
{
846 by Brian Aker
Removing on typedeffed class.
1271
  Select_Lex *first_sl= first_select();
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1272
  assert(!fake_select_lex);
1 by brian
clean slate
1273
846 by Brian Aker
Removing on typedeffed class.
1274
  if (!(fake_select_lex= new (session_arg->mem_root) Select_Lex()))
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1275
      return(1);
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
1276
  fake_select_lex->include_standalone(this,
847 by Brian Aker
More typdef class removal.
1277
                                      (Select_Lex_Node**)&fake_select_lex);
1 by brian
clean slate
1278
  fake_select_lex->select_number= INT_MAX;
520.1.22 by Brian Aker
Second pass of thd cleanup
1279
  fake_select_lex->parent_lex= session_arg->lex; /* Used in init_query. */
1 by brian
clean slate
1280
  fake_select_lex->make_empty_select();
1281
  fake_select_lex->linkage= GLOBAL_OPTIONS_TYPE;
1282
  fake_select_lex->select_limit= 0;
1283
1284
  fake_select_lex->context.outer_context=first_sl->context.outer_context;
1273.2.9 by Stewart Smith
fix accidental mangling of comment: s/order_st BY/ORDER BY/. in sql_parse.cc
1285
  /* allow item list resolving in fake select for ORDER BY */
55 by brian
Update for using real bool types.
1286
  fake_select_lex->context.resolve_in_select_list= true;
1 by brian
clean slate
1287
  fake_select_lex->context.select_lex= fake_select_lex;
1288
1289
  if (!is_union())
1290
  {
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
1291
    /*
1292
      This works only for
1273.2.9 by Stewart Smith
fix accidental mangling of comment: s/order_st BY/ORDER BY/. in sql_parse.cc
1293
      (SELECT ... ORDER BY list [LIMIT n]) ORDER BY order_list [LIMIT m],
1294
      (SELECT ... LIMIT n) ORDER BY order_list [LIMIT m]
1 by brian
clean slate
1295
      just before the parser starts processing order_list
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
1296
    */
1 by brian
clean slate
1297
    global_parameters= fake_select_lex;
1298
    fake_select_lex->no_table_names_allowed= 1;
520.1.22 by Brian Aker
Second pass of thd cleanup
1299
    session_arg->lex->current_select= fake_select_lex;
1 by brian
clean slate
1300
  }
520.1.22 by Brian Aker
Second pass of thd cleanup
1301
  session_arg->lex->pop_context();
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1302
  return(0);
1 by brian
clean slate
1303
}
1304
1305
1306
/**
1307
  Push a new name resolution context for a JOIN ... ON clause to the
1308
  context stack of a query block.
1309
1310
    Create a new name resolution context for a JOIN ... ON clause,
1311
    set the first and last leaves of the list of table references
1312
    to be used for name resolution, and push the newly created
1313
    context to the stack of contexts of the query.
1314
520.1.22 by Brian Aker
Second pass of thd cleanup
1315
  @param session       pointer to current thread
1 by brian
clean slate
1316
  @param left_op   left  operand of the JOIN
1317
  @param right_op  rigth operand of the JOIN
1318
1319
  @retval
55 by brian
Update for using real bool types.
1320
    false  if all is OK
1 by brian
clean slate
1321
  @retval
55 by brian
Update for using real bool types.
1322
    true   if a memory allocation error occured
1 by brian
clean slate
1323
*/
1324
1325
bool
520.1.22 by Brian Aker
Second pass of thd cleanup
1326
push_new_name_resolution_context(Session *session,
327.2.4 by Brian Aker
Refactoring table.h
1327
                                 TableList *left_op, TableList *right_op)
1 by brian
clean slate
1328
{
1329
  Name_resolution_context *on_context;
520.1.22 by Brian Aker
Second pass of thd cleanup
1330
  if (!(on_context= new (session->mem_root) Name_resolution_context))
55 by brian
Update for using real bool types.
1331
    return true;
1 by brian
clean slate
1332
  on_context->init();
1333
  on_context->first_name_resolution_table=
1334
    left_op->first_leaf_for_name_resolution();
1335
  on_context->last_name_resolution_table=
1336
    right_op->last_leaf_for_name_resolution();
520.1.22 by Brian Aker
Second pass of thd cleanup
1337
  return session->lex->push_context(on_context);
1 by brian
clean slate
1338
}
1339
1340
1341
/**
1342
  Add an ON condition to the second operand of a JOIN ... ON.
1343
1344
    Add an ON condition to the right operand of a JOIN ... ON clause.
1345
1346
  @param b     the second operand of a JOIN ... ON
1347
  @param expr  the condition to be added to the ON clause
1348
1349
  @retval
55 by brian
Update for using real bool types.
1350
    false  if there was some error
1 by brian
clean slate
1351
  @retval
55 by brian
Update for using real bool types.
1352
    true   if all is OK
1 by brian
clean slate
1353
*/
1354
327.2.4 by Brian Aker
Refactoring table.h
1355
void add_join_on(TableList *b, Item *expr)
1 by brian
clean slate
1356
{
1357
  if (expr)
1358
  {
1359
    if (!b->on_expr)
1360
      b->on_expr= expr;
1361
    else
1362
    {
1363
      /*
1364
        If called from the parser, this happens if you have both a
1365
        right and left join. If called later, it happens if we add more
1366
        than one condition to the ON clause.
1367
      */
1368
      b->on_expr= new Item_cond_and(b->on_expr,expr);
1369
    }
1370
    b->on_expr->top_level_item();
1371
  }
1372
}
1373
1374
1375
/**
1376
  Mark that there is a NATURAL JOIN or JOIN ... USING between two
1377
  tables.
1378
1379
    This function marks that table b should be joined with a either via
1380
    a NATURAL JOIN or via JOIN ... USING. Both join types are special
1381
    cases of each other, so we treat them together. The function
1382
    setup_conds() creates a list of equal condition between all fields
1383
    of the same name for NATURAL JOIN or the fields in 'using_fields'
1384
    for JOIN ... USING. The list of equality conditions is stored
1385
    either in b->on_expr, or in JOIN::conds, depending on whether there
1386
    was an outer join.
1387
1388
  EXAMPLE
1389
  @verbatim
1390
    SELECT * FROM t1 NATURAL LEFT JOIN t2
1391
     <=>
1392
    SELECT * FROM t1 LEFT JOIN t2 ON (t1.i=t2.i and t1.j=t2.j ... )
1393
1394
    SELECT * FROM t1 NATURAL JOIN t2 WHERE <some_cond>
1395
     <=>
1396
    SELECT * FROM t1, t2 WHERE (t1.i=t2.i and t1.j=t2.j and <some_cond>)
1397
1398
    SELECT * FROM t1 JOIN t2 USING(j) WHERE <some_cond>
1399
     <=>
1400
    SELECT * FROM t1, t2 WHERE (t1.j=t2.j and <some_cond>)
1401
   @endverbatim
1402
1403
  @param a		  Left join argument
1404
  @param b		  Right join argument
1405
  @param using_fields    Field names from USING clause
1406
*/
1407
327.2.4 by Brian Aker
Refactoring table.h
1408
void add_join_natural(TableList *a, TableList *b, List<String> *using_fields,
846 by Brian Aker
Removing on typedeffed class.
1409
                      Select_Lex *lex)
1 by brian
clean slate
1410
{
1411
  b->natural_join= a;
1412
  lex->prev_join_using= using_fields;
1413
}
1414
1415
1416
/**
1417
  kill on thread.
1418
520.1.22 by Brian Aker
Second pass of thd cleanup
1419
  @param session			Thread class
1 by brian
clean slate
1420
  @param id			Thread id
1421
  @param only_kill_query        Should it kill the query or the connection
1422
1423
  @note
1424
    This is written such that we have a short lock on LOCK_thread_count
1425
*/
1426
230.1.9 by Monty Taylor
Merged in remove-include-dir.
1427
static unsigned int
1317.2.13 by Monty Taylor
Fix the use of isViewable in processlist Generator to properly skip
1428
kill_one_thread(Session *, ulong id, bool only_kill_query)
1 by brian
clean slate
1429
{
1014.7.3 by Nathan Williams
Reformatted refactored bits per monty's suggestion.
1430
  Session *tmp= NULL;
1317.2.6 by Monty Taylor
Prevent the user from attempting to kill a process that he is not authorized
1431
  uint32_t error= ER_NO_SUCH_THREAD;
1689.2.8 by Brian Aker
LOCK_thread_count -> boost.
1432
  LOCK_thread_count.lock(); // For unlink from list
1014.7.1 by Nathan Williams
Replaced global I_List<Session> with std::vector<Session*>
1433
  
1320.1.14 by Brian Aker
Small style issue.
1434
  for (SessionList::iterator it= getSessionList().begin(); it != getSessionList().end(); ++it )
1 by brian
clean slate
1435
  {
1014.7.3 by Nathan Williams
Reformatted refactored bits per monty's suggestion.
1436
    if ((*it)->thread_id == id)
1 by brian
clean slate
1437
    {
1014.7.3 by Nathan Williams
Reformatted refactored bits per monty's suggestion.
1438
      tmp= *it;
1689.3.7 by Brian Aker
Covnert session lock
1439
      tmp->lockForDelete();
1 by brian
clean slate
1440
      break;
1441
    }
1442
  }
1689.2.8 by Brian Aker
LOCK_thread_count -> boost.
1443
  LOCK_thread_count.unlock();
1 by brian
clean slate
1444
  if (tmp)
1445
  {
1317.2.6 by Monty Taylor
Prevent the user from attempting to kill a process that he is not authorized
1446
1317.2.12 by Monty Taylor
Use isViewable also in kill.
1447
    if (tmp->isViewable())
1317.2.6 by Monty Taylor
Prevent the user from attempting to kill a process that he is not authorized
1448
    {
1449
      tmp->awake(only_kill_query ? Session::KILL_QUERY : Session::KILL_CONNECTION);
1450
      error= 0;
1451
    }
1452
1689.3.7 by Brian Aker
Covnert session lock
1453
    tmp->unlockForDelete();
1 by brian
clean slate
1454
  }
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1455
  return(error);
1 by brian
clean slate
1456
}
1457
1458
1459
/*
1460
  kills a thread and sends response
1461
1462
  SYNOPSIS
1463
    sql_kill()
520.1.22 by Brian Aker
Second pass of thd cleanup
1464
    session			Thread class
1 by brian
clean slate
1465
    id			Thread id
1466
    only_kill_query     Should it kill the query or the connection
1467
*/
1468
520.1.22 by Brian Aker
Second pass of thd cleanup
1469
void sql_kill(Session *session, ulong id, bool only_kill_query)
1 by brian
clean slate
1470
{
438.1.13 by Brian Aker
uint cleanup.
1471
  uint32_t error;
520.1.22 by Brian Aker
Second pass of thd cleanup
1472
  if (!(error= kill_one_thread(session, id, only_kill_query)))
836 by Brian Aker
Fixed session call from function to method.
1473
    session->my_ok();
1 by brian
clean slate
1474
  else
1475
    my_error(error, MYF(0), id);
1476
}
1477
1478
1479
/**
1480
  Check if the select is a simple select (not an union).
1481
1482
  @retval
1483
    0	ok
1484
  @retval
1485
    1	error	; In this case the error messege is sent to the client
1486
*/
1487
1488
bool check_simple_select()
1489
{
520.1.22 by Brian Aker
Second pass of thd cleanup
1490
  Session *session= current_session;
1491
  LEX *lex= session->lex;
1 by brian
clean slate
1492
  if (lex->current_select != &lex->select_lex)
1493
  {
1494
    char command[80];
520.1.22 by Brian Aker
Second pass of thd cleanup
1495
    Lex_input_stream *lip= session->m_lip;
629.5.2 by Toru Maesaka
Second pass of replacing MySQL's strmake() with libc calls
1496
    strncpy(command, lip->yylval->symbol.str,
1067.4.4 by Nathan Williams
The rest of the files in the drizzled directory were purged of the cmin macro and replace with std::min (except for the definition in globals.h and 1 usage in stacktrace.cc).
1497
            min(lip->yylval->symbol.length, (uint32_t)(sizeof(command)-1)));
1498
    command[min(lip->yylval->symbol.length, (uint32_t)(sizeof(command)-1))]=0;
1 by brian
clean slate
1499
    my_error(ER_CANT_USE_OPTION_HERE, MYF(0), command);
1500
    return 1;
1501
  }
1502
  return 0;
1503
}
1504
1505
1506
/**
1507
  Construct ALL/ANY/SOME subquery Item.
1508
1509
  @param left_expr   pointer to left expression
1510
  @param cmp         compare function creator
1511
  @param all         true if we create ALL subquery
1512
  @param select_lex  pointer on parsed subquery structure
1513
1514
  @return
1515
    constructed Item (or 0 if out of memory)
1516
*/
1517
Item * all_any_subquery_creator(Item *left_expr,
584.1.15 by Monty Taylor
The mega-patch from hell. Renamed sql_class to session (since that's what it is) and removed it and field and table from common_includes.
1518
                                chooser_compare_func_creator cmp,
1519
                                bool all,
846 by Brian Aker
Removing on typedeffed class.
1520
                                Select_Lex *select_lex)
1 by brian
clean slate
1521
{
1522
  if ((cmp == &comp_eq_creator) && !all)       //  = ANY <=> IN
1523
    return new Item_in_subselect(left_expr, select_lex);
1524
1525
  if ((cmp == &comp_ne_creator) && all)        // <> ALL <=> NOT IN
1526
    return new Item_func_not(new Item_in_subselect(left_expr, select_lex));
1527
1528
  Item_allany_subselect *it=
1529
    new Item_allany_subselect(left_expr, cmp, select_lex, all);
1530
  if (all)
1531
    return it->upper_item= new Item_func_not_all(it);	/* ALL */
1532
1533
  return it->upper_item= new Item_func_nop_all(it);      /* ANY/SOME */
1534
}
1535
1536
1537
/**
826 by Brian Aker
Simplify update
1538
  Update query pre-check.
1 by brian
clean slate
1539
520.1.22 by Brian Aker
Second pass of thd cleanup
1540
  @param session		Thread handler
1 by brian
clean slate
1541
  @param tables	Global/local table list (have to be the same)
1542
1543
  @retval
55 by brian
Update for using real bool types.
1544
    false OK
1 by brian
clean slate
1545
  @retval
55 by brian
Update for using real bool types.
1546
    true  Error
1 by brian
clean slate
1547
*/
1548
826 by Brian Aker
Simplify update
1549
bool update_precheck(Session *session, TableList *)
1 by brian
clean slate
1550
{
1551
  const char *msg= 0;
520.1.22 by Brian Aker
Second pass of thd cleanup
1552
  LEX *lex= session->lex;
846 by Brian Aker
Removing on typedeffed class.
1553
  Select_Lex *select_lex= &lex->select_lex;
1 by brian
clean slate
1554
826 by Brian Aker
Simplify update
1555
  if (session->lex->select_lex.item_list.elements != session->lex->value_list.elements)
1 by brian
clean slate
1556
  {
1557
    my_message(ER_WRONG_VALUE_COUNT, ER(ER_WRONG_VALUE_COUNT), MYF(0));
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1558
    return(true);
1 by brian
clean slate
1559
  }
1560
826 by Brian Aker
Simplify update
1561
  if (session->lex->select_lex.table_list.elements > 1)
1 by brian
clean slate
1562
  {
826 by Brian Aker
Simplify update
1563
    if (select_lex->order_list.elements)
1564
      msg= "ORDER BY";
1565
    else if (select_lex->select_limit)
1566
      msg= "LIMIT";
1567
    if (msg)
1568
    {
1569
      my_error(ER_WRONG_USAGE, MYF(0), "UPDATE", msg);
1570
      return(true);
1571
    }
1 by brian
clean slate
1572
  }
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1573
  return(false);
1 by brian
clean slate
1574
}
1575
1576
1577
/**
1578
  simple INSERT query pre-check.
1579
520.1.22 by Brian Aker
Second pass of thd cleanup
1580
  @param session		Thread handler
1 by brian
clean slate
1581
  @param tables	Global table list
1582
1583
  @retval
55 by brian
Update for using real bool types.
1584
    false  OK
1 by brian
clean slate
1585
  @retval
55 by brian
Update for using real bool types.
1586
    true   error
1 by brian
clean slate
1587
*/
1588
575.1.2 by Monty Taylor
Changed a bunch of __attribute__((unused)) to removing the parameter name instead.
1589
bool insert_precheck(Session *session, TableList *)
1 by brian
clean slate
1590
{
520.1.22 by Brian Aker
Second pass of thd cleanup
1591
  LEX *lex= session->lex;
1 by brian
clean slate
1592
1593
  /*
1594
    Check that we have modify privileges for the first table and
1595
    select privileges for the rest
1596
  */
1597
  if (lex->update_list.elements != lex->value_list.elements)
1598
  {
1599
    my_message(ER_WRONG_VALUE_COUNT, ER(ER_WRONG_VALUE_COUNT), MYF(0));
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1600
    return(true);
1 by brian
clean slate
1601
  }
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1602
  return(false);
1 by brian
clean slate
1603
}
1604
1605
1606
/**
1607
  CREATE TABLE query pre-check.
1608
520.1.22 by Brian Aker
Second pass of thd cleanup
1609
  @param session			Thread handler
1 by brian
clean slate
1610
  @param tables		Global table list
1611
  @param create_table	        Table which will be created
1612
1613
  @retval
55 by brian
Update for using real bool types.
1614
    false   OK
1 by brian
clean slate
1615
  @retval
55 by brian
Update for using real bool types.
1616
    true   Error
1 by brian
clean slate
1617
*/
1618
1223.4.1 by Brian Aker
Table Identifier patch.
1619
bool create_table_precheck(TableIdentifier &identifier)
1 by brian
clean slate
1620
{
1320.1.8 by Brian Aker
Temporary fix for allowing engines to say "don't do this".
1621
  if (not plugin::StorageEngine::canCreateTable(identifier))
1273.13.1 by Brian Aker
First pass through data dictionary.
1622
  {
1358.1.9 by Brian Aker
Update for std::string
1623
    my_error(ER_DBACCESS_DENIED_ERROR, MYF(0), "", "", identifier.getSchemaName().c_str());
1273.13.1 by Brian Aker
First pass through data dictionary.
1624
    return true;
1625
  }
1 by brian
clean slate
1626
1395.1.12 by Brian Aker
Fixes failure related to Heap's hack on deletion. Also cleans up error
1627
  if (not plugin::StorageEngine::doesSchemaExist(identifier))
1628
  {
1629
    my_error(ER_BAD_DB_ERROR, MYF(0), identifier.getSchemaName().c_str());
1630
    return true;
1631
  }
1632
1223.4.1 by Brian Aker
Table Identifier patch.
1633
  return false;
1 by brian
clean slate
1634
}
1635
1636
1637
/**
1638
  negate given expression.
1639
520.1.22 by Brian Aker
Second pass of thd cleanup
1640
  @param session  thread handler
1 by brian
clean slate
1641
  @param expr expression for negation
1642
1643
  @return
1644
    negated expression
1645
*/
1646
520.1.22 by Brian Aker
Second pass of thd cleanup
1647
Item *negate_expression(Session *session, Item *expr)
1 by brian
clean slate
1648
{
1649
  Item *negated;
1650
  if (expr->type() == Item::FUNC_ITEM &&
1651
      ((Item_func *) expr)->functype() == Item_func::NOT_FUNC)
1652
  {
1653
    /* it is NOT(NOT( ... )) */
1654
    Item *arg= ((Item_func *) expr)->arguments()[0];
520.1.22 by Brian Aker
Second pass of thd cleanup
1655
    enum_parsing_place place= session->lex->current_select->parsing_place;
1 by brian
clean slate
1656
    if (arg->is_bool_func() || place == IN_WHERE || place == IN_HAVING)
1657
      return arg;
1658
    /*
1659
      if it is not boolean function then we have to emulate value of
1660
      not(not(a)), it will be a != 0
1661
    */
1662
    return new Item_func_ne(arg, new Item_int((char*) "0", 0, 1));
1663
  }
1664
520.1.22 by Brian Aker
Second pass of thd cleanup
1665
  if ((negated= expr->neg_transformer(session)) != 0)
1 by brian
clean slate
1666
    return negated;
1667
  return new Item_func_not(expr);
1668
}
1669
1670
1671
/*
1672
  Check that char length of a string does not exceed some limit.
1673
1674
  SYNOPSIS
1675
  check_string_char_length()
1676
      str              string to be checked
1677
      err_msg          error message to be displayed if the string is too long
1678
      max_char_length  max length in symbols
1679
      cs               string charset
1680
1681
  RETURN
55 by brian
Update for using real bool types.
1682
    false   the passed string is not longer than max_char_length
1683
    true    the passed string is longer than max_char_length
1 by brian
clean slate
1684
*/
1685
1686
1687
bool check_string_char_length(LEX_STRING *str, const char *err_msg,
438.1.13 by Brian Aker
uint cleanup.
1688
                              uint32_t max_char_length, const CHARSET_INFO * const cs,
1 by brian
clean slate
1689
                              bool no_error)
1690
{
1691
  int well_formed_error;
438.1.13 by Brian Aker
uint cleanup.
1692
  uint32_t res= cs->cset->well_formed_len(cs, str->str, str->str + str->length,
1 by brian
clean slate
1693
                                      max_char_length, &well_formed_error);
1694
1695
  if (!well_formed_error &&  str->length == res)
55 by brian
Update for using real bool types.
1696
    return false;
1 by brian
clean slate
1697
1698
  if (!no_error)
1699
    my_error(ER_WRONG_STRING_LENGTH, MYF(0), str->str, err_msg, max_char_length);
55 by brian
Update for using real bool types.
1700
  return true;
1 by brian
clean slate
1701
}
1702
1703
575.4.7 by Monty Taylor
More header cleanup.
1704
bool check_identifier_name(LEX_STRING *str, uint32_t err_code,
1705
                           uint32_t max_char_length,
1706
                           const char *param_for_err_msg)
1 by brian
clean slate
1707
{
1708
  /*
1709
    We don't support non-BMP characters in identifiers at the moment,
1710
    so they should be prohibited until such support is done.
1711
    This is why we use the 3-byte utf8 to check well-formedness here.
1712
  */
760 by Brian Aker
Cleanup around UTf8 code.
1713
  const CHARSET_INFO * const cs= &my_charset_utf8mb4_general_ci;
1714
1 by brian
clean slate
1715
  int well_formed_error;
438.1.13 by Brian Aker
uint cleanup.
1716
  uint32_t res= cs->cset->well_formed_len(cs, str->str, str->str + str->length,
1 by brian
clean slate
1717
                                      max_char_length, &well_formed_error);
1718
1719
  if (well_formed_error)
1720
  {
1721
    my_error(ER_INVALID_CHARACTER_STRING, MYF(0), "identifier", str->str);
55 by brian
Update for using real bool types.
1722
    return true;
1 by brian
clean slate
1723
  }
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
1724
1 by brian
clean slate
1725
  if (str->length == res)
55 by brian
Update for using real bool types.
1726
    return false;
1 by brian
clean slate
1727
1728
  switch (err_code)
1729
  {
1730
  case 0:
1731
    break;
1732
  case ER_WRONG_STRING_LENGTH:
1733
    my_error(err_code, MYF(0), str->str, param_for_err_msg, max_char_length);
1734
    break;
1735
  case ER_TOO_LONG_IDENT:
1736
    my_error(err_code, MYF(0), str->str);
1737
    break;
1738
  default:
51.1.61 by Jay Pipes
Removed/replaced BUG symbols and standardized TRUE/FALSE
1739
    assert(0);
1 by brian
clean slate
1740
    break;
1741
  }
55 by brian
Update for using real bool types.
1742
  return true;
1 by brian
clean slate
1743
}
1744
1745
1746
/**
520.4.50 by Monty Taylor
Finish changing the bison namespace argument from MYSQL to DRIZZLE
1747
  This is a wrapper of DRIZZLEparse(). All the code should call parse_sql()
1748
  instead of DRIZZLEparse().
1 by brian
clean slate
1749
520.1.22 by Brian Aker
Second pass of thd cleanup
1750
  @param session Thread context.
1 by brian
clean slate
1751
  @param lip Lexer context.
1752
1753
  @return Error status.
55 by brian
Update for using real bool types.
1754
    @retval false on success.
1755
    @retval true on parsing error.
1 by brian
clean slate
1756
*/
1757
1165.1.48 by Stewart Smith
make parse_sql static to sql_parse.cc
1758
static bool parse_sql(Session *session, Lex_input_stream *lip)
1 by brian
clean slate
1759
{
520.1.22 by Brian Aker
Second pass of thd cleanup
1760
  assert(session->m_lip == NULL);
1 by brian
clean slate
1761
1280.3.16 by Padraig O'Sullivan
Updated the calls to dtrace probes to use the c_str() pointer from query in Session
1762
  DRIZZLE_QUERY_PARSE_START(session->query.c_str());
1126.10.15 by Padraig O'Sullivan
Added calls to the parsing related dtrace probes.
1763
1 by brian
clean slate
1764
  /* Set Lex_input_stream. */
1765
520.1.22 by Brian Aker
Second pass of thd cleanup
1766
  session->m_lip= lip;
1 by brian
clean slate
1767
1768
  /* Parse the query. */
1769
520.4.50 by Monty Taylor
Finish changing the bison namespace argument from MYSQL to DRIZZLE
1770
  bool mysql_parse_status= DRIZZLEparse(session) != 0;
520.1.22 by Brian Aker
Second pass of thd cleanup
1771
520.4.50 by Monty Taylor
Finish changing the bison namespace argument from MYSQL to DRIZZLE
1772
  /* Check that if DRIZZLEparse() failed, session->is_error() is set. */
520.1.22 by Brian Aker
Second pass of thd cleanup
1773
1774
  assert(!mysql_parse_status || session->is_error());
1 by brian
clean slate
1775
1776
  /* Reset Lex_input_stream. */
1777
520.1.22 by Brian Aker
Second pass of thd cleanup
1778
  session->m_lip= NULL;
1 by brian
clean slate
1779
1126.10.15 by Padraig O'Sullivan
Added calls to the parsing related dtrace probes.
1780
  DRIZZLE_QUERY_PARSE_DONE(mysql_parse_status || session->is_fatal_error);
1781
1 by brian
clean slate
1782
  /* That's it. */
1783
520.1.22 by Brian Aker
Second pass of thd cleanup
1784
  return mysql_parse_status || session->is_fatal_error;
1 by brian
clean slate
1785
}
1786
1787
/**
1788
  @} (end of group Runtime_Environment)
1789
*/
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
1790
1791
} /* namespace drizzled */