diff options
author | Ulrich Drepper <drepper@redhat.com> | 2008-06-26 00:42:12 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2008-06-26 00:42:12 +0000 |
commit | 104426b6542145c5c5be9ccc4a32afb2dbb05674 (patch) | |
tree | 3c13449d4c075efc808637e568894f0f4d5060d6 /localedata | |
parent | 4cb8e687affcc5323b2a330ac55d40a15d573ccf (diff) | |
download | glibc-104426b6542145c5c5be9ccc4a32afb2dbb05674.tar.gz glibc-104426b6542145c5c5be9ccc4a32afb2dbb05674.tar.xz glibc-104426b6542145c5c5be9ccc4a32afb2dbb05674.zip |
[BZ #6654]
2008-06-25 Ulrich Drepper <drepper@redhat.com> [BZ #6654] * stdlib/canonicalize.c (__realpath): readlink can write too much into the buffer on platforms without PATH_MAX.
Diffstat (limited to 'localedata')
-rw-r--r-- | localedata/ChangeLog | 3 | ||||
-rw-r--r-- | localedata/tst-strptime.c | 25 |
2 files changed, 26 insertions, 2 deletions
diff --git a/localedata/ChangeLog b/localedata/ChangeLog index 257c58a89c..a1ffc8d50f 100644 --- a/localedata/ChangeLog +++ b/localedata/ChangeLog @@ -1,5 +1,8 @@ 2008-06-25 Ulrich Drepper <drepper@redhat.com> + * tst-strptime.c (do_test): Add test for parsing era year + representation. + [BZ #5911] * locales/es_CR: Define first_weekday and first_workday. diff --git a/localedata/tst-strptime.c b/localedata/tst-strptime.c index b5ab232d7e..a95b2c2611 100644 --- a/localedata/tst-strptime.c +++ b/localedata/tst-strptime.c @@ -1,22 +1,43 @@ #include <locale.h> #include <time.h> #include <stdio.h> +#include <string.h> static int do_test (void) { + int result = 0; + if (setlocale (LC_ALL, "vi_VN.TCVN5712-1") == NULL) { puts ("cannot set locale"); return 1; } struct tm tm; + memset (&tm, '\0', sizeof (tm)); /* This is November in Vietnamese encoded using TCVN5712-1. */ static const char s[] = "\ -\x54\x68\xb8\x6e\x67\x20\x6d\xad\xea\x69\x20\x6d\xe9\x74"; +\x54\x68\xb8\x6e\x67\x20\x6d\xad\xea\x69\x20\x6d\xe9\x74\0"; char *r = strptime (s, "%b", &tm); printf ("r = %p, r-s = %tu, tm.tm_mon = %d\n", r, r - s, tm.tm_mon); - return r == NULL || r - s != 14 || tm.tm_mon != 10; + result = r == NULL || r - s != 14 || tm.tm_mon != 10; + + if (setlocale (LC_ALL, "ja_JP.UTF-8") == NULL) + { + puts ("cannot set locale"); + return 1; + } + static const char s2[] = "\ +\x32\x35\x20\x30\x36\x20\xe5\xb9\xb3\xe6\x88\x90\x32\x30\0"; + memset (&tm, '\0', sizeof (tm)); + r = strptime (s2, "%d %m %EC%Ey", &tm); + printf ("\ +r = %p, r-s2 = %tu, tm.tm_mday = %d, tm.tm_mon = %d, tm.tm_year = %d\n", + r, r - s2, tm.tm_mday, tm.tm_mon, tm.tm_year); + result = (r == NULL || r - s2 != 14 || tm.tm_mday != 25 || tm.tm_mon != 5 + || tm.tm_year != 108); + + return result; } #define TEST_FUNCTION do_test () |