[1.7] wctomb bug
Eric Blake
ebb9@byu.net
Thu Feb 26 21:11:00 GMT 2009
Simple test case. This application uses the C locale (by virtue of the fact
that we did not use setlocale(), and evidenced by mb_cur_max of 1). On Linux,
this correctly shows wctomb rejecting the conversion (0x100 is too big to fit
in a 1-byte sequence) with EILSEQ, but newlib currently truncates the invalid
wchar_t value to int and returns 1.
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <wchar.h>
#include <string.h>
#include <limits.h>
int main (int argc, char **argv)
{
wchar_t w = 0x100;
char str[MB_LEN_MAX];
int i = wctomb(str, w);
printf("mb_cur_max %zd, len %d, str[0] 0x%02hhx, errno %d\n",
MB_CUR_MAX, i, str[0], errno);
return 0;
}
--
Eric Blake
--
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
Problem reports: http://cygwin.com/problems.html
Documentation: http://cygwin.com/docs.html
FAQ: http://cygwin.com/faq/
More information about the Cygwin
mailing list