summaryrefslogtreecommitdiff
path: root/mysys/charset.c
diff options
context:
space:
mode:
authorunknown <ramil@mysql.com>2005-04-26 15:43:20 +0500
committerunknown <ramil@mysql.com>2005-04-26 15:43:20 +0500
commit2c7f351e9d3145f256d843c237381eedc5c6dc1f (patch)
tree53b8086d2c8f362453a09687a1432aa00407ee4a /mysys/charset.c
parent608c8df34f9ec83f20e69660234cddd2e90ce5ec (diff)
downloadmariadb-git-2c7f351e9d3145f256d843c237381eedc5c6dc1f.tar.gz
A fix (bug #9756: mysql client failing on dumps containing certain \ sequences).
mysys/charset.c: A fix (bug #9756: mysql client failing on dumps containing certain \ sequences). As 'to_end' points to the last position we should use '>' comparison instead of '>=' there. 'l' replaced with 'tmp_length' (in order not to mix 'l' with '1').
Diffstat (limited to 'mysys/charset.c')
-rw-r--r--mysys/charset.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/mysys/charset.c b/mysys/charset.c
index a4a8205a3f9..534a6aa998e 100644
--- a/mysys/charset.c
+++ b/mysys/charset.c
@@ -581,15 +581,15 @@ ulong escape_string_for_mysql(CHARSET_INFO *charset_info,
{
char escape=0;
#ifdef USE_MB
- int l;
- if (use_mb_flag && (l= my_ismbchar(charset_info, from, end)))
+ int tmp_length;
+ if (use_mb_flag && (tmp_length= my_ismbchar(charset_info, from, end)))
{
- if (to + l >= to_end)
+ if (to + tmp_length > to_end)
{
overflow=1;
break;
}
- while (l--)
+ while (tmp_length--)
*to++= *from++;
from--;
continue;
@@ -605,7 +605,7 @@ ulong escape_string_for_mysql(CHARSET_INFO *charset_info,
multi-byte character into a valid one. For example, 0xbf27 is not
a valid GBK character, but 0xbf5c is. (0x27 = ', 0x5c = \)
*/
- if (use_mb_flag && (l= my_mbcharlen(charset_info, *from)) > 1)
+ if (use_mb_flag && (tmp_length= my_mbcharlen(charset_info, *from)) > 1)
escape= *from;
else
#endif
@@ -634,7 +634,7 @@ ulong escape_string_for_mysql(CHARSET_INFO *charset_info,
}
if (escape)
{
- if (to + 2 >= to_end)
+ if (to + 2 > to_end)
{
overflow=1;
break;
@@ -644,7 +644,7 @@ ulong escape_string_for_mysql(CHARSET_INFO *charset_info,
}
else
{
- if (to + 1 >= to_end)
+ if (to + 1 > to_end)
{
overflow=1;
break;