diff options
author | Ulrich Drepper <drepper@redhat.com> | 2006-04-25 17:47:32 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2006-04-25 17:47:32 +0000 |
commit | 74ed1159d1588e7012e7c91dea8d85202ed715de (patch) | |
tree | 33286a577ad565465b76ac96fc675e76d79d9849 | |
parent | bdefc84c58dc5d7b4f9152359a06d5deb55aa146 (diff) | |
download | glibc-74ed1159d1588e7012e7c91dea8d85202ed715de.tar.gz glibc-74ed1159d1588e7012e7c91dea8d85202ed715de.tar.xz glibc-74ed1159d1588e7012e7c91dea8d85202ed715de.zip |
[BZ #2569]
2006-04-25 Ulrich Drepper <drepper@redhat.com> [BZ #2569] * iconv/gconv_db.c (__gconv_release_step): Fix condition of assert call. * iconvdata/Makefile (tests): Add tst-iconv6. * iconvdata/tst-iconv6.c: New file.
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | iconv/gconv_db.c | 4 | ||||
-rw-r--r-- | iconvdata/Makefile | 3 | ||||
-rw-r--r-- | iconvdata/tst-iconv6.c | 35 |
4 files changed, 47 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog index 52945b0cfd..9e143582a8 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2006-04-25 Ulrich Drepper <drepper@redhat.com> + + [BZ #2569] + * iconv/gconv_db.c (__gconv_release_step): Fix condition of assert + call. + * iconvdata/Makefile (tests): Add tst-iconv6. + * iconvdata/tst-iconv6.c: New file. + 2006-04-24 Ulrich Drepper <drepper@redhat.com> * posix/tst-rfc3484.c (do_test): Also initialize source_addr_flags diff --git a/iconv/gconv_db.c b/iconv/gconv_db.c index 3431ce0812..6540cc393c 100644 --- a/iconv/gconv_db.c +++ b/iconv/gconv_db.c @@ -1,5 +1,5 @@ /* Provide access to the collection of available transformation modules. - Copyright (C) 1997-2003, 2004, 2005 Free Software Foundation, Inc. + Copyright (C) 1997-2003, 2004, 2005, 2006 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997. @@ -227,7 +227,7 @@ __gconv_release_step (struct __gconv_step *step) step->__shlib_handle = NULL; #endif } - else + else if (step->__shlib_handle == NULL) /* Builtin modules should not have end functions. */ assert (step->__end_fct == NULL); } diff --git a/iconvdata/Makefile b/iconvdata/Makefile index 1c80df16cf..1d3259179a 100644 --- a/iconvdata/Makefile +++ b/iconvdata/Makefile @@ -65,7 +65,8 @@ modules.so := $(addsuffix .so, $(modules)) include ../Makeconfig ifeq (yes,$(build-shared)) -tests = bug-iconv1 bug-iconv2 tst-loading tst-e2big tst-iconv4 bug-iconv4 +tests = bug-iconv1 bug-iconv2 tst-loading tst-e2big tst-iconv4 bug-iconv4 \ + tst-iconv6 ifeq ($(have-thread-library),yes) tests += bug-iconv3 endif diff --git a/iconvdata/tst-iconv6.c b/iconvdata/tst-iconv6.c new file mode 100644 index 0000000000..accb21b113 --- /dev/null +++ b/iconvdata/tst-iconv6.c @@ -0,0 +1,35 @@ +/* BZ #2569 */ + +#include <iconv.h> +#include <stdio.h> + +static int +do_test (void) +{ + iconv_t cd0 = iconv_open ("ISO-8859-7", "UTF-16LE"); + if (cd0 == (iconv_t) -1) + { + puts ("first iconv_open failed"); + return 1; + } + iconv_t cd1 = iconv_open ("ISO-8859-7", "UTF-16LE"); + if (cd1 == (iconv_t) -1) + { + puts ("second iconv_open failed"); + return 1; + } + if (iconv_close (cd0) != 0) + { + puts ("first iconv_close failed"); + return 1; + } + if (iconv_close (cd1) != 0) + { + puts ("second iconv_close failed"); + return 1; + } + return 0; +} + +#define TEST_FUNCTION do_test () +#include "../test-skeleton.c" |