summaryrefslogtreecommitdiff
path: root/mysys/my_once.c
diff options
context:
space:
mode:
authorAlexander Barkov <bar@mysql.com>2010-11-12 13:12:15 +0300
committerAlexander Barkov <bar@mysql.com>2010-11-12 13:12:15 +0300
commit1b583fa5da71a764dd66ad8b3668d7c75b122444 (patch)
tree857de10f04663e23de6cfb4be01edfbda425279e /mysys/my_once.c
parentaa668865e271694e9b3ebbfe518cb4d0c2ad0c38 (diff)
downloadmariadb-git-1b583fa5da71a764dd66ad8b3668d7c75b122444.tar.gz
Bug#58005 utf8 + get_format causes failed assertion: !str || str != Ptr'
Problem: When GET_FORMAT() is called two times from the upper level function (e.g. LEAST in the bug report), on the second call "res= args[0]->val_str(...)" and str point to the same String object. 1. Fix: changing the order from - get val_str into tmp_value then convert to str to - get val_str into str then convert to tmp_value The new order is more correct: the purpose of "str" parameter is exactly to call val_str() for arguments. The purpose of String class members (like tmp_value) is to do further actions on the result. Doing it in the other way around give unexpected surprises. 2. Using str_value instead of str to do padding, for the same reason.
Diffstat (limited to 'mysys/my_once.c')
0 files changed, 0 insertions, 0 deletions