Commit 12621f34 authored by dlenev@mysql.com's avatar dlenev@mysql.com

Merge bk-internal.mysql.com:/home/bk/mysql-4.1

into mysql.com:/home/dlenev/src/mysql-4.1-bg9913
parents 1ad41d37 8ee6d33b
...@@ -1691,6 +1691,13 @@ longlong Item_func_bit_count::val_int() ...@@ -1691,6 +1691,13 @@ longlong Item_func_bit_count::val_int()
#ifdef HAVE_DLOPEN #ifdef HAVE_DLOPEN
udf_handler::~udf_handler() udf_handler::~udf_handler()
{
/* Everything should be properly cleaned up by this moment. */
DBUG_ASSERT(not_original || !(initialized || buffers));
}
void udf_handler::cleanup()
{ {
if (!not_original) if (!not_original)
{ {
...@@ -1703,9 +1710,11 @@ udf_handler::~udf_handler() ...@@ -1703,9 +1710,11 @@ udf_handler::~udf_handler()
(*deinit)(&initid); (*deinit)(&initid);
} }
free_udf(u_d); free_udf(u_d);
initialized= FALSE;
} }
if (buffers) // Because of bug in ecc if (buffers) // Because of bug in ecc
delete [] buffers; delete [] buffers;
buffers= 0;
} }
} }
...@@ -1945,6 +1954,12 @@ String *udf_handler::val_str(String *str,String *save_str) ...@@ -1945,6 +1954,12 @@ String *udf_handler::val_str(String *str,String *save_str)
} }
void Item_udf_func::cleanup()
{
udf.cleanup();
Item_func::cleanup();
}
double Item_func_udf_float::val() double Item_func_udf_float::val()
{ {
......
...@@ -783,6 +783,7 @@ class Item_udf_func :public Item_func ...@@ -783,6 +783,7 @@ class Item_udf_func :public Item_func
fixed= 1; fixed= 1;
return res; return res;
} }
void cleanup();
Item_result result_type () const { return udf.result_type(); } Item_result result_type () const { return udf.result_type(); }
table_map not_null_tables() const { return 0; } table_map not_null_tables() const { return 0; }
}; };
......
...@@ -1449,6 +1449,17 @@ bool Item_udf_sum::add() ...@@ -1449,6 +1449,17 @@ bool Item_udf_sum::add()
DBUG_RETURN(0); DBUG_RETURN(0);
} }
void Item_udf_sum::cleanup()
{
/*
udf_handler::cleanup() nicely handles case when we have not
original item but one created by copy_or_same() method.
*/
udf.cleanup();
Item_sum::cleanup();
}
Item *Item_sum_udf_float::copy_or_same(THD* thd) Item *Item_sum_udf_float::copy_or_same(THD* thd)
{ {
return new (thd->mem_root) Item_sum_udf_float(thd, this); return new (thd->mem_root) Item_sum_udf_float(thd, this);
......
...@@ -550,6 +550,7 @@ class Item_udf_sum : public Item_sum ...@@ -550,6 +550,7 @@ class Item_udf_sum : public Item_sum
bool add(); bool add();
void reset_field() {}; void reset_field() {};
void update_field() {}; void update_field() {};
void cleanup();
}; };
......
...@@ -67,6 +67,7 @@ class udf_handler :public Sql_alloc ...@@ -67,6 +67,7 @@ class udf_handler :public Sql_alloc
bool get_arguments(); bool get_arguments();
bool fix_fields(THD *thd,struct st_table_list *tlist,Item_result_field *item, bool fix_fields(THD *thd,struct st_table_list *tlist,Item_result_field *item,
uint arg_count,Item **args); uint arg_count,Item **args);
void cleanup();
double val(my_bool *null_value) double val(my_bool *null_value)
{ {
if (get_arguments()) if (get_arguments())
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment