mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
MDEV-30879 Add support for up to BASE 62 to CONV()
BASE 62 uses 0-9, A-Z and then a-z to give the numbers 0-61. This patch increases the range of the string functions to cover this. Based on ideas and tests in PR #2589, but re-written into the charset functions. Includes fix by Sergei, UBSAN complained: ctype-simple.c:683:38: runtime error: negation of -9223372036854775808 cannot be represented in type 'long long int'; cast to an unsigned type to negate this value to itself Co-authored-by: Weijun Huang <huangweijun1001@gmail.com> Co-authored-by: Sergei Golubchik <serg@mariadb.org>
This commit is contained in:
committed by
Andrew Hutchings
parent
be6d48fd53
commit
f552febe43
@@ -3936,8 +3936,8 @@ String *Item_func_conv::val_str(String *str)
|
||||
// Note that abs(INT_MIN) is undefined.
|
||||
if (args[0]->null_value || args[1]->null_value || args[2]->null_value ||
|
||||
from_base == INT_MIN || to_base == INT_MIN ||
|
||||
abs(to_base) > 36 || abs(to_base) < 2 ||
|
||||
abs(from_base) > 36 || abs(from_base) < 2 || !(res->length()))
|
||||
abs(to_base) > 62 || abs(to_base) < 2 ||
|
||||
abs(from_base) > 62 || abs(from_base) < 2 || !(res->length()))
|
||||
{
|
||||
null_value= 1;
|
||||
return NULL;
|
||||
|
Reference in New Issue
Block a user