summaryrefslogtreecommitdiff
path: root/sql/sql_class.cc
diff options
context:
space:
mode:
authorunknown <sergefp@mysql.com>2004-04-08 17:08:56 +0400
committerunknown <sergefp@mysql.com>2004-04-08 17:08:56 +0400
commit718d1f0aa7dd94f6bcadbb8418ad26db9b8f2c57 (patch)
tree72c1a87b4e8eec4fa218606afa87f91b72e1cba4 /sql/sql_class.cc
parent94002eb59512e78df76922ae5c2204359fc306e4 (diff)
parent4ceaf3a6292e08e33ba4e985e72e72d87cd9743f (diff)
downloadmariadb-git-718d1f0aa7dd94f6bcadbb8418ad26db9b8f2c57.tar.gz
Merge
sql/item.cc: Auto merged sql/mysql_priv.h: Auto merged sql/mysqld.cc: Auto merged sql/sql_class.cc: Auto merged sql/sql_class.h: Auto merged sql/sql_lex.h: Auto merged sql/sql_parse.cc: Auto merged sql/sql_prepare.cc: Auto merged sql/sql_yacc.yy: SCCS merged
Diffstat (limited to 'sql/sql_class.cc')
-rw-r--r--sql/sql_class.cc23
1 files changed, 22 insertions, 1 deletions
diff --git a/sql/sql_class.cc b/sql/sql_class.cc
index 1b4c8bec416..49fa0455a30 100644
--- a/sql/sql_class.cc
+++ b/sql/sql_class.cc
@@ -78,6 +78,23 @@ extern "C" void free_user_var(user_var_entry *entry)
my_free((char*) entry,MYF(0));
}
+/****************************************************************************
+** SQL syntax names for Prepared Statements
+****************************************************************************/
+
+extern "C" byte *get_stmt_key(SQL_PREP_STMT_ENTRY *entry, uint *length,
+ my_bool not_used __attribute__((unused)))
+{
+ *length=(uint) entry->name.length;
+ return (byte*) entry->name.str;
+}
+
+extern "C" void free_sql_stmt(SQL_PREP_STMT_ENTRY *entry)
+{
+ char *pos= (char*) entry+ALIGN_SIZE(sizeof(*entry));
+ my_free((char*) entry,MYF(0));
+}
+
/****************************************************************************
** Thread specific functions
@@ -160,7 +177,10 @@ THD::THD():user_time(0), current_statement(0), is_fatal_error(0),
16);
else
bzero((char*) &user_var_events, sizeof(user_var_events));
-
+
+ hash_init(&sql_prepared_stmts, &my_charset_bin, USER_VARS_HASH_SIZE, 0, 0,
+ (hash_get_key) get_stmt_key,
+ (hash_free_key) free_sql_stmt,0);
/* Protocol */
protocol= &protocol_simple; // Default protocol
protocol_simple.init(this);
@@ -279,6 +299,7 @@ void THD::cleanup(void)
my_free((char*) variables.datetime_format, MYF(MY_ALLOW_ZERO_PTR));
delete_dynamic(&user_var_events);
hash_free(&user_vars);
+ hash_free(&sql_prepared_stmts);
if (global_read_lock)
unlock_global_read_lock(this);
if (ull)