mirror of
https://github.com/MariaDB/server.git
synced 2026-05-03 13:45:34 +02:00
Merging from 5.1.
This commit is contained in:
commit
498a5bbc82
4 changed files with 34 additions and 9 deletions
|
|
@ -1684,6 +1684,21 @@ ARMENIAN CAPIT ECH 2
|
||||||
ARMENIAN CAPIT ZA 2
|
ARMENIAN CAPIT ZA 2
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
#
|
#
|
||||||
|
# Start of 5.1 tests
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Bug#58371 Assertion failed: !s.uses_buffer_owned_by(this) with format string function
|
||||||
|
#
|
||||||
|
SET NAMES latin1;
|
||||||
|
DO CONVERT(CAST(SUBSTRING_INDEX(FORMAT(1,'1111'), FORMAT('','Zpq'),1)
|
||||||
|
AS BINARY(0)) USING utf8);
|
||||||
|
Warnings:
|
||||||
|
Warning 1292 Truncated incorrect INTEGER value: 'Zpq'
|
||||||
|
Warning 1292 Truncated incorrect BINARY(0) value: '1.'
|
||||||
|
#
|
||||||
|
# End of 5.1 tests
|
||||||
|
#
|
||||||
|
#
|
||||||
# Start of 5.5 tests
|
# Start of 5.5 tests
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
|
|
|
||||||
|
|
@ -216,6 +216,21 @@ DROP TABLE t1;
|
||||||
# End of 4.1 tests
|
# End of 4.1 tests
|
||||||
|
|
||||||
|
|
||||||
|
--echo #
|
||||||
|
--echo # Start of 5.1 tests
|
||||||
|
--echo #
|
||||||
|
|
||||||
|
--echo #
|
||||||
|
--echo # Bug#58371 Assertion failed: !s.uses_buffer_owned_by(this) with format string function
|
||||||
|
--echo #
|
||||||
|
|
||||||
|
SET NAMES latin1;
|
||||||
|
DO CONVERT(CAST(SUBSTRING_INDEX(FORMAT(1,'1111'), FORMAT('','Zpq'),1)
|
||||||
|
AS BINARY(0)) USING utf8);
|
||||||
|
--echo #
|
||||||
|
--echo # End of 5.1 tests
|
||||||
|
--echo #
|
||||||
|
|
||||||
--echo #
|
--echo #
|
||||||
--echo # Start of 5.5 tests
|
--echo # Start of 5.5 tests
|
||||||
--echo #
|
--echo #
|
||||||
|
|
|
||||||
|
|
@ -2959,22 +2959,16 @@ String *Item_func_conv_charset::val_str(String *str)
|
||||||
DBUG_ASSERT(fixed == 1);
|
DBUG_ASSERT(fixed == 1);
|
||||||
if (use_cached_value)
|
if (use_cached_value)
|
||||||
return null_value ? 0 : &str_value;
|
return null_value ? 0 : &str_value;
|
||||||
/*
|
String *arg= args[0]->val_str(str);
|
||||||
Here we don't pass 'str' as a parameter to args[0]->val_str()
|
|
||||||
as 'str' may point to 'str_value' (e.g. see Item::save_in_field()),
|
|
||||||
which we use below to convert string.
|
|
||||||
Use argument's 'str_value' instead.
|
|
||||||
*/
|
|
||||||
String *arg= args[0]->val_str(&args[0]->str_value);
|
|
||||||
uint dummy_errors;
|
uint dummy_errors;
|
||||||
if (!arg)
|
if (!arg)
|
||||||
{
|
{
|
||||||
null_value=1;
|
null_value=1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
null_value= str_value.copy(arg->ptr(),arg->length(),arg->charset(),
|
null_value= tmp_value.copy(arg->ptr(), arg->length(), arg->charset(),
|
||||||
conv_charset, &dummy_errors);
|
conv_charset, &dummy_errors);
|
||||||
return null_value ? 0 : check_well_formed_result(&str_value);
|
return null_value ? 0 : check_well_formed_result(&tmp_value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Item_func_conv_charset::fix_length_and_dec()
|
void Item_func_conv_charset::fix_length_and_dec()
|
||||||
|
|
|
||||||
|
|
@ -791,6 +791,7 @@ public:
|
||||||
class Item_func_conv_charset :public Item_str_func
|
class Item_func_conv_charset :public Item_str_func
|
||||||
{
|
{
|
||||||
bool use_cached_value;
|
bool use_cached_value;
|
||||||
|
String tmp_value;
|
||||||
public:
|
public:
|
||||||
bool safe;
|
bool safe;
|
||||||
CHARSET_INFO *conv_charset; // keep it public
|
CHARSET_INFO *conv_charset; // keep it public
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue