summaryrefslogtreecommitdiff
path: root/sql/item.cc
diff options
context:
space:
mode:
authorEvgeny Potemkin <epotemkin@mysql.com>2009-11-24 18:26:13 +0300
committerEvgeny Potemkin <epotemkin@mysql.com>2009-11-24 18:26:13 +0300
commit9f638f535e63b4bbe7cddfda153ddedad02f3f8a (patch)
tree6e715efd003d16cfc130e158eb707c3c7249c158 /sql/item.cc
parentfad34c34cf22eb1c503204aee204dfb83ad7acea (diff)
parentbc43bff7edf79095c243cf6858acb29213fb152b (diff)
downloadmariadb-git-9f638f535e63b4bbe7cddfda153ddedad02f3f8a.tar.gz
Manual merge of the fix for bug#43668.
Diffstat (limited to 'sql/item.cc')
-rw-r--r--sql/item.cc106
1 files changed, 64 insertions, 42 deletions
diff --git a/sql/item.cc b/sql/item.cc
index e1dbc1ba21a..ed6628dd84c 100644
--- a/sql/item.cc
+++ b/sql/item.cc
@@ -6957,7 +6957,7 @@ Item_cache* Item_cache::get_cache(const Item *item, const Item_result type)
{
switch (type) {
case INT_RESULT:
- return new Item_cache_int();
+ return new Item_cache_int(item->field_type());
case REAL_RESULT:
return new Item_cache_real();
case DECIMAL_RESULT:
@@ -6975,8 +6975,9 @@ Item_cache* Item_cache::get_cache(const Item *item, const Item_result type)
void Item_cache::store(Item *item)
{
- if (item)
- example= item;
+ example= item;
+ if (!item)
+ null_value= TRUE;
value_cached= FALSE;
}
@@ -6990,12 +6991,15 @@ void Item_cache::print(String *str, enum_query_type query_type)
str->append(')');
}
-void Item_cache_int::cache_value()
+bool Item_cache_int::cache_value()
{
+ if (!example)
+ return FALSE;
value_cached= TRUE;
value= example->val_int_result();
null_value= example->null_value;
unsigned_flag= example->unsigned_flag;
+ return TRUE;
}
@@ -7012,8 +7016,8 @@ void Item_cache_int::store(Item *item, longlong val_arg)
String *Item_cache_int::val_str(String *str)
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
str->set(value, default_charset());
return str;
}
@@ -7022,8 +7026,8 @@ String *Item_cache_int::val_str(String *str)
my_decimal *Item_cache_int::val_decimal(my_decimal *decimal_val)
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
int2my_decimal(E_DEC_FATAL_ERROR, value, unsigned_flag, decimal_val);
return decimal_val;
}
@@ -7031,40 +7035,43 @@ my_decimal *Item_cache_int::val_decimal(my_decimal *decimal_val)
double Item_cache_int::val_real()
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0.0;
return (double) value;
}
longlong Item_cache_int::val_int()
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0;
return value;
}
-void Item_cache_real::cache_value()
+bool Item_cache_real::cache_value()
{
+ if (!example)
+ return FALSE;
value_cached= TRUE;
value= example->val_result();
null_value= example->null_value;
+ return TRUE;
}
double Item_cache_real::val_real()
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0.0;
return value;
}
longlong Item_cache_real::val_int()
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0;
return (longlong) rint(value);
}
@@ -7072,8 +7079,8 @@ longlong Item_cache_real::val_int()
String* Item_cache_real::val_str(String *str)
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
str->set_real(value, decimals, default_charset());
return str;
}
@@ -7082,27 +7089,30 @@ String* Item_cache_real::val_str(String *str)
my_decimal *Item_cache_real::val_decimal(my_decimal *decimal_val)
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
double2my_decimal(E_DEC_FATAL_ERROR, value, decimal_val);
return decimal_val;
}
-void Item_cache_decimal::cache_value()
+bool Item_cache_decimal::cache_value()
{
+ if (!example)
+ return FALSE;
value_cached= TRUE;
my_decimal *val= example->val_decimal_result(&decimal_value);
if (!(null_value= example->null_value) && val != &decimal_value)
my_decimal2decimal(val, &decimal_value);
+ return TRUE;
}
double Item_cache_decimal::val_real()
{
DBUG_ASSERT(fixed);
double res;
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
my_decimal2double(E_DEC_FATAL_ERROR, &decimal_value, &res);
return res;
}
@@ -7111,8 +7121,8 @@ longlong Item_cache_decimal::val_int()
{
DBUG_ASSERT(fixed);
longlong res;
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0;
my_decimal2int(E_DEC_FATAL_ERROR, &decimal_value, unsigned_flag, &res);
return res;
}
@@ -7120,8 +7130,8 @@ longlong Item_cache_decimal::val_int()
String* Item_cache_decimal::val_str(String *str)
{
DBUG_ASSERT(fixed);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
my_decimal_round(E_DEC_FATAL_ERROR, &decimal_value, decimals, FALSE,
&decimal_value);
my_decimal2string(E_DEC_FATAL_ERROR, &decimal_value, 0, 0, 0, str);
@@ -7131,14 +7141,16 @@ String* Item_cache_decimal::val_str(String *str)
my_decimal *Item_cache_decimal::val_decimal(my_decimal *val)
{
DBUG_ASSERT(fixed);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
return &decimal_value;
}
-void Item_cache_str::cache_value()
+bool Item_cache_str::cache_value()
{
+ if (!example)
+ return FALSE;
value_cached= TRUE;
value_buff.set(buffer, sizeof(buffer), example->collation.collation);
value= example->str_result(&value_buff);
@@ -7157,6 +7169,7 @@ void Item_cache_str::cache_value()
value_buff.copy(*value);
value= &value_buff;
}
+ return TRUE;
}
double Item_cache_str::val_real()
@@ -7164,8 +7177,8 @@ double Item_cache_str::val_real()
DBUG_ASSERT(fixed == 1);
int err_not_used;
char *end_not_used;
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0.0;
if (value)
return my_strntod(value->charset(), (char*) value->ptr(),
value->length(), &end_not_used, &err_not_used);
@@ -7177,8 +7190,8 @@ longlong Item_cache_str::val_int()
{
DBUG_ASSERT(fixed == 1);
int err;
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0;
if (value)
return my_strntoll(value->charset(), value->ptr(),
value->length(), 10, (char**) 0, &err);
@@ -7190,8 +7203,8 @@ longlong Item_cache_str::val_int()
String* Item_cache_str::val_str(String *str)
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0;
return value;
}
@@ -7199,8 +7212,8 @@ String* Item_cache_str::val_str(String *str)
my_decimal *Item_cache_str::val_decimal(my_decimal *decimal_val)
{
DBUG_ASSERT(fixed == 1);
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return NULL;
if (value)
string2my_decimal(E_DEC_FATAL_ERROR, value, decimal_val);
else
@@ -7211,8 +7224,8 @@ my_decimal *Item_cache_str::val_decimal(my_decimal *decimal_val)
int Item_cache_str::save_in_field(Field *field, bool no_conversions)
{
- if (!value_cached)
- cache_value();
+ if (!value_cached && !cache_value())
+ return 0;
int res= Item_cache::save_in_field(field, no_conversions);
return (is_varbinary && field->type() == MYSQL_TYPE_STRING &&
value->length() < field->field_length) ? 1 : res;
@@ -7247,13 +7260,21 @@ bool Item_cache_row::setup(Item * item)
void Item_cache_row::store(Item * item)
{
+ example= item;
+ if (!item)
+ {
+ null_value= TRUE;
+ return;
+ }
for (uint i= 0; i < item_count; i++)
values[i]->store(item->element_index(i));
}
-void Item_cache_row::cache_value()
+bool Item_cache_row::cache_value()
{
+ if (!example)
+ return FALSE;
value_cached= TRUE;
null_value= 0;
example->bring_value();
@@ -7262,6 +7283,7 @@ void Item_cache_row::cache_value()
values[i]->cache_value();
null_value|= values[i]->null_value;
}
+ return TRUE;
}