forked from lattera/glibc
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix a bug when converting strings with 1 character using TCVN5712-1
It isn't necessary to buffer the last character of strings. This can cause a bug with strings that have 1 character between 0x0041 and 0x01b0. [BZ #13691] * iconvdata/tcvn5712-1.c (FROM_LOOP): Fix a bug when converting strings with only 1 character between 0x0041 and 0x01b0. * wcsmbs/Makefile (tests): Add tst-mbsnrtowcs. * wcsmbs/tst-mbsnrtowcs.c: New file.
- Loading branch information
Showing
5 changed files
with
99 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,11 @@ | ||
2012-03-30 Tulio Magno Quites Machado Filho <[email protected]> | ||
|
||
[BZ #13691] | ||
* iconvdata/tcvn5712-1.c (FROM_LOOP): Fix a bug when converting strings | ||
with only 1 character between 0x0041 and 0x01b0. | ||
* wcsmbs/Makefile (tests): Add tst-mbsnrtowcs. | ||
* wcsmbs/tst-mbsnrtowcs.c: New file. | ||
|
||
2012-03-29 David S. Miller <[email protected]> | ||
|
||
* libio/fileops.c (_IO_new_file_xsputn): Don't try to optimize | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
/* Conversion to and from TCVN5712-1. | ||
Copyright (C) 2001, 2002, 2004, 2011 Free Software Foundation, Inc. | ||
Copyright (C) 2001-2012 Free Software Foundation, Inc. | ||
This file is part of the GNU C Library. | ||
Contributed by Ulrich Drepper <[email protected]>, 2001. | ||
|
@@ -379,7 +379,7 @@ static const struct | |
last_ch = *statep >> 3; \ | ||
\ | ||
/* We have to buffer ch if it is a possible match in comp_table_data. */ \ | ||
must_buffer_ch = (ch >= 0x0041 && ch <= 0x01b0); \ | ||
must_buffer_ch = last_ch && (ch >= 0x0041 && ch <= 0x01b0); \ | ||
\ | ||
if (last_ch) \ | ||
{ \ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
/* Copyright (C) 2012 Free Software Foundation, Inc. | ||
This file is part of the GNU C Library. | ||
Contributed by Tulio Magno Quites Machado Filho <[email protected]>, | ||
2012. | ||
The GNU C Library is free software; you can redistribute it and/or | ||
modify it under the terms of the GNU Lesser General Public | ||
License as published by the Free Software Foundation; either | ||
version 2.1 of the License, or (at your option) any later version. | ||
The GNU C Library is distributed in the hope that it will be useful, | ||
but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
Lesser General Public License for more details. | ||
You should have received a copy of the GNU Lesser General Public | ||
License along with the GNU C Library; if not, see | ||
<http://www.gnu.org/licenses/>. */ | ||
|
||
/* Test bugzilla 13691 */ | ||
|
||
#include <stdio.h> | ||
#include <string.h> | ||
#include <wchar.h> | ||
#include <locale.h> | ||
|
||
static int | ||
do_test (void) | ||
{ | ||
const char * in = "A"; | ||
const char *inbuf = in; | ||
size_t inlen = strchr (in, '\0') - inbuf; | ||
|
||
wchar_t out[5]; | ||
mbstate_t ps; | ||
|
||
const char *locale = "vi_VN.TCVN5712-1"; | ||
if (!setlocale (LC_ALL, locale)) | ||
{ | ||
printf ("Locale not available.\n"); | ||
return 1; | ||
} | ||
|
||
memset (&ps, '\0', sizeof (ps)); | ||
memset (out, '\0', sizeof (out)); | ||
|
||
/* If the bug isn't fixed, it isn't going to return from mbsnrtowcs due to | ||
an assert(). */ | ||
size_t n = mbsnrtowcs (out, &inbuf, inlen, sizeof(out) - 1, &ps); | ||
|
||
int result = 0; | ||
|
||
if (n != 1) | ||
{ | ||
printf ("n = %zu, expected 1\n", n); | ||
result = 1; | ||
} | ||
|
||
int i; | ||
printf ("in = "); | ||
for (i = 0; i < inlen; i++) | ||
{ | ||
printf ("0x%X ", in[i]); | ||
} | ||
printf ("\n"); | ||
|
||
char * outb = (char *) out; | ||
printf ("out ="); | ||
for (i = 0; i < sizeof (out); i++) | ||
{ | ||
if (i % 4 == 0) | ||
{ | ||
printf (" 0x"); | ||
} | ||
printf ("%X", outb[i]); | ||
} | ||
printf ("\n"); | ||
|
||
return result; | ||
} | ||
|
||
#define TEST_FUNCTION do_test () | ||
#include "../test-skeleton.c" |