diff options
author | monty@mysql.com <> | 2005-07-28 16:10:14 +0300 |
---|---|---|
committer | monty@mysql.com <> | 2005-07-28 16:10:14 +0300 |
commit | b3cbd0048fe5fe36fe4fba9ce591b0d1b26e10a1 (patch) | |
tree | af22629d2c36ae4196e6f23584c4cecc393b874e /sql-common | |
parent | 510d9a19e1dc52a4d07fb5c601cd4cb3dd6aca4a (diff) | |
download | mariadb-git-b3cbd0048fe5fe36fe4fba9ce591b0d1b26e10a1.tar.gz |
Cleanups during review of new code
Ensure mysql_close() is called if mysql_set_character_set() fails
Diffstat (limited to 'sql-common')
-rw-r--r-- | sql-common/client.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/sql-common/client.c b/sql-common/client.c index 4ecc8d26fc7..4ec919553c6 100644 --- a/sql-common/client.c +++ b/sql-common/client.c @@ -2206,14 +2206,22 @@ my_bool mysql_reconnect(MYSQL *mysql) tmp_mysql.rpl_pivot = mysql->rpl_pivot; if (!mysql_real_connect(&tmp_mysql,mysql->host,mysql->user,mysql->passwd, mysql->db, mysql->port, mysql->unix_socket, - mysql->client_flag | CLIENT_REMEMBER_OPTIONS) || - mysql_set_character_set(&tmp_mysql, mysql->charset->csname)) + mysql->client_flag | CLIENT_REMEMBER_OPTIONS)) { mysql->net.last_errno= tmp_mysql.net.last_errno; strmov(mysql->net.last_error, tmp_mysql.net.last_error); strmov(mysql->net.sqlstate, tmp_mysql.net.sqlstate); DBUG_RETURN(1); } + if (mysql_set_character_set(&tmp_mysql, mysql->charset->csname)) + { + mysql_close(&tmp_mysql); + mysql->net.last_errno= tmp_mysql.net.last_errno; + strmov(mysql->net.last_error, tmp_mysql.net.last_error); + strmov(mysql->net.sqlstate, tmp_mysql.net.sqlstate); + DBUG_RETURN(1); + } + tmp_mysql.reconnect= 1; tmp_mysql.free_me= mysql->free_me; |