X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Ftsticonv.c;h=61492b5fc65690255be6856e443c26fe2e546269;hb=4d35e2e6ab9c8d544292cbd94a574dec6694cf9a;hp=a011c372f21cb2247110fe62fbd9f04e6e7b3487;hpb=1b22167f72a2de519e28be87aad12b1633cad835;p=yaz-moved-to-github.git diff --git a/test/tsticonv.c b/test/tsticonv.c index a011c37..61492b5 100644 --- a/test/tsticonv.c +++ b/test/tsticonv.c @@ -2,7 +2,7 @@ * Copyright (C) 1995-2005, Index Data ApS * See the file LICENSE for details. * - * $Id: tsticonv.c,v 1.8 2005-02-02 23:27:05 adam Exp $ + * $Id: tsticonv.c,v 1.12 2005-10-28 18:36:59 adam Exp $ */ #if HAVE_CONFIG_H @@ -17,33 +17,33 @@ #include static int compare_buffers(char *msg, int no, - int expect_len, const unsigned char *expect_buf, - int got_len, const unsigned char *got_buf) + int expect_len, const char *expect_buf, + int got_len, const char *got_buf) { int i; if (expect_len == got_len - && !memcmp(expect_buf, got_buf, expect_len)) - return 1; + && !memcmp(expect_buf, got_buf, expect_len)) + return 1; printf("tsticonv test=%s i=%d failed\n", msg, no); printf("off got exp\n"); for (i = 0; i 12) - outbytesleft = 12; + while (inbytesleft) + { + size_t outbytesleft = outbuf0 + sizeof(outbuf0) - outbuf; + if (outbytesleft > 12) + outbytesleft = 12; r = yaz_iconv(cd, &inbuf, &inbytesleft, &outbuf, &outbytesleft); if (r == (size_t) (-1)) { int e = yaz_iconv_error(cd); - if (e != YAZ_ICONV_E2BIG) - { + if (e != YAZ_ICONV_E2BIG) + { printf ("tsticonv 21 i=%d e=%d\n", i, e); - exit(21); - } - } - else - break; + exit(21); + } + } + else + break; } - compare_buffers("tsticonv 22", i, - expect_len, ar[i].ucs4_b, - outbuf - outbuf0, outbuf0); + compare_buffers("tsticonv 22", i, + expect_len, ar[i].ucs4_b, + outbuf - outbuf0, outbuf0); } yaz_iconv_close(cd); } @@ -203,14 +217,14 @@ static void tst_marc8_to_ucs4b() static void tst_ucs4b_to_utf8() { static const char *ucs4_c[] = { - "\x00\x00\xFF\x1F\x00\x00\x00o", - "\x00\x00\xAE\x0E\x00\x00\xC0\xF4", - 0 + "\x00\x00\xFF\x1F\x00\x00\x00o", + "\x00\x00\xAE\x0E\x00\x00\xC0\xF4", + 0 }; static const char *utf8_c[] = { - "\xEF\xBC\x9F\x6F", - "\xEA\xB8\x8E\xEC\x83\xB4", - 0 + "\xEF\xBC\x9F\x6F", + "\xEA\xB8\x8E\xEC\x83\xB4", + 0 }; int i; @@ -219,8 +233,8 @@ static void tst_ucs4b_to_utf8() cd = yaz_iconv_open("UTF8", "UCS4"); if (!cd) { - printf ("tsticonv 30 yaz_iconv_open failed\n"); - exit(30); + printf ("tsticonv 30 yaz_iconv_open failed\n"); + exit(30); } for (i = 0; ucs4_c[i]; i++) { @@ -237,11 +251,11 @@ static void tst_ucs4b_to_utf8() int e = yaz_iconv_error(cd); printf ("tsticonv 31 i=%d e=%d\n", i, e); - exit(31); + exit(31); } - compare_buffers("tsticonv 32", i, - strlen(utf8_c[i]), utf8_c[i], - outbuf - outbuf0, outbuf0); + compare_buffers("tsticonv 32", i, + strlen(utf8_c[i]), utf8_c[i], + outbuf - outbuf0, outbuf0); } yaz_iconv_close(cd); } @@ -253,58 +267,58 @@ static void dconvert(int mandatory, const char *tmpcode) for (i = 0; iso_8859_1_a[i]; i++) { size_t r; - char *inbuf = (char*) iso_8859_1_a[i]; - size_t inbytesleft = strlen(inbuf); - char outbuf0[24]; - char outbuf1[10]; - char *outbuf = outbuf0; - size_t outbytesleft = sizeof(outbuf0); + char *inbuf = (char*) iso_8859_1_a[i]; + size_t inbytesleft = strlen(inbuf); + char outbuf0[24]; + char outbuf1[10]; + char *outbuf = outbuf0; + size_t outbytesleft = sizeof(outbuf0); cd = yaz_iconv_open(tmpcode, "ISO-8859-1"); - if (!cd) + if (!cd) { if (!mandatory) return; - printf ("tsticonv code=%s 1\n", tmpcode); - exit(1); + printf ("tsticonv code=%s i=%d 1\n", tmpcode, i); + exit(1); } - r = yaz_iconv(cd, &inbuf, &inbytesleft, &outbuf, &outbytesleft); - if (r == (size_t)(-1)) + r = yaz_iconv(cd, &inbuf, &inbytesleft, &outbuf, &outbytesleft); + if (r == (size_t)(-1)) { int e = yaz_iconv_error(cd); - printf ("tsticonv code=%s 2 e=%d\n", tmpcode, e); - exit(2); + printf ("tsticonv code=%s i=%d 2 e=%d\n", tmpcode, i, e); + exit(2); } - yaz_iconv_close(cd); + yaz_iconv_close(cd); - cd = yaz_iconv_open("ISO-8859-1", tmpcode); - if (!cd) + cd = yaz_iconv_open("ISO-8859-1", tmpcode); + if (!cd) { if (!mandatory) return; - printf ("tsticonv code=%s 3\n", tmpcode); - exit(3); + printf ("tsticonv code=%s i=%d 3\n", tmpcode, i); + exit(3); } - inbuf = outbuf0; - inbytesleft = sizeof(outbuf0) - outbytesleft; + inbuf = outbuf0; + inbytesleft = sizeof(outbuf0) - outbytesleft; - outbuf = outbuf1; - outbytesleft = sizeof(outbuf1); - r = yaz_iconv(cd, &inbuf, &inbytesleft, &outbuf, &outbytesleft); - if (r == (size_t)(-1)) { + outbuf = outbuf1; + outbytesleft = sizeof(outbuf1); + r = yaz_iconv(cd, &inbuf, &inbytesleft, &outbuf, &outbytesleft); + if (r == (size_t)(-1)) { int e = yaz_iconv_error(cd); - printf ("tsticonv code=%s 4 e=%d\n", tmpcode, e); - exit(4); - } - compare_buffers("dconvert", i, - strlen(iso_8859_1_a[i]), iso_8859_1_a[i], - sizeof(outbuf1) - outbytesleft, outbuf1); - yaz_iconv_close(cd); + printf ("tsticonv code=%s i=%d 4 e=%d\n", tmpcode, i, e); + exit(4); + } + compare_buffers("dconvert", i, + strlen(iso_8859_1_a[i]), iso_8859_1_a[i], + sizeof(outbuf1) - outbytesleft, outbuf1); + yaz_iconv_close(cd); } } - + int main (int argc, char **argv) { dconvert(1, "UTF-8"); @@ -315,5 +329,13 @@ int main (int argc, char **argv) tst_marc8_to_iso_8859_1(); tst_marc8_to_ucs4b(); tst_ucs4b_to_utf8(); - exit (0); + exit(0); } +/* + * Local variables: + * c-basic-offset: 4 + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +