diff options
author | unknown <lars@mysql.com/black.(none)> | 2006-12-08 23:33:15 +0100 |
---|---|---|
committer | unknown <lars@mysql.com/black.(none)> | 2006-12-08 23:33:15 +0100 |
commit | 5aa8705ab66618f386b81da38f4228b83fb8de4d (patch) | |
tree | bdcf053375046c3a14574b82eaba5e40ffde8a58 /sql/set_var.cc | |
parent | b121562b3828682b2cfd94d218bc48698d33b1dd (diff) | |
parent | 4474cc8493fb999b1fea4da739177c146909ddef (diff) | |
download | mariadb-git-5aa8705ab66618f386b81da38f4228b83fb8de4d.tar.gz |
Merge mysql.com:/home/bkroot/mysql-4.1-rpl
into mysql.com:/home/bk/MERGE/mysql-4.1-merge
sql/item_timefunc.cc:
Auto merged
sql/set_var.cc:
Auto merged
Diffstat (limited to 'sql/set_var.cc')
-rw-r--r-- | sql/set_var.cc | 35 |
1 files changed, 27 insertions, 8 deletions
diff --git a/sql/set_var.cc b/sql/set_var.cc index 71ca382f9d9..30724c78a62 100644 --- a/sql/set_var.cc +++ b/sql/set_var.cc @@ -2570,19 +2570,38 @@ void sys_var_thd_time_zone::set_default(THD *thd, enum_var_type type) bool sys_var_thd_lc_time_names::check(THD *thd, set_var *var) { - char *locale_str =var->value->str_value.c_ptr(); - MY_LOCALE *locale_match= my_locale_by_name(locale_str); + MY_LOCALE *locale_match; - if(locale_match == NULL) + if (var->value->result_type() == INT_RESULT) { - my_printf_error(ER_UNKNOWN_ERROR, "Unknown locale: '%s'", MYF(0), locale_str); - return 1; + if (!(locale_match= my_locale_by_number((uint) var->value->val_int()))) + { + char buf[20]; + int10_to_str((int) var->value->val_int(), buf, -10); + my_printf_error(ER_UNKNOWN_ERROR, "Unknown locale: '%s'", MYF(0), buf); + return 1; + } } - else + else // STRING_RESULT { - var->save_result.locale_value= locale_match; - return 0; + char buff[6]; + String str(buff, sizeof(buff), &my_charset_latin1), *res; + if (!(res=var->value->val_str(&str))) + { + my_error(ER_WRONG_VALUE_FOR_VAR, MYF(0), name, "NULL"); + return 1; + } + const char *locale_str= res->c_ptr(); + if (!(locale_match= my_locale_by_name(locale_str))) + { + my_printf_error(ER_UNKNOWN_ERROR, + "Unknown locale: '%s'", MYF(0), locale_str); + return 1; + } } + + var->save_result.locale_value= locale_match; + return 0; } |