diff options
author | jimw@mysql.com <> | 2005-02-15 11:31:01 -0800 |
---|---|---|
committer | jimw@mysql.com <> | 2005-02-15 11:31:01 -0800 |
commit | e2291bdc7e973ccdc4298fc44069268851c1839f (patch) | |
tree | 2942069b3c0860fe3aab590bc51515d0f43ab93e /mysys/charset.c | |
parent | 5bb39302abab8ecd4214b214d9de46c551053a3d (diff) | |
download | mariadb-git-e2291bdc7e973ccdc4298fc44069268851c1839f.tar.gz |
Only escape the first character in a sequence of bytes that appears to be
a multibyte character, but was not a valid multibyte character. Refinement
of fix for Bug #8378.
Diffstat (limited to 'mysys/charset.c')
-rw-r--r-- | mysys/charset.c | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/mysys/charset.c b/mysys/charset.c index 934125ead4a..5587a6d685f 100644 --- a/mysys/charset.c +++ b/mysys/charset.c @@ -583,9 +583,10 @@ ulong escape_string_for_mysql(CHARSET_INFO *charset_info, char *to, } /* If the next character appears to begin a multi-byte character, we - escape all of the bytes of that apparent character. (The character just - looks like a multi-byte character -- if it were actually a multi-byte - character, it would have been passed through in the test above.) + escape that first byte of that apparent multi-byte character. (The + character just looks like a multi-byte character -- if it were actually + a multi-byte character, it would have been passed through in the test + above.) Without this check, we can create a problem by converting an invalid multi-byte character into a valid one. For example, 0xbf27 is not @@ -593,12 +594,8 @@ ulong escape_string_for_mysql(CHARSET_INFO *charset_info, char *to, */ if (use_mb_flag && (l= my_mbcharlen(charset_info, *from)) > 1) { - while (l--) - { - *to++= '\\'; - *to++= *from++; - } - from--; + *to++= '\\'; + *to++= *from; continue; } #endif |