freebsd-ports/converters/iconv/files/patch-lib::converter.c
Akinori MUSHA dc2cf7c4bc Add a patch to fix a bug where iconv() did not return -1 properly on
conversion error.  This fixes null conversion and all the case where
errno is set.

Bump PORTREVISION.

Approved by:	Konstantin Chuguev <Konstantin.Chuguev@dante.org.uk>
		(MAINTAINER, Author)
Reported by:	Nobuyoshi Nakada <nobu.nakada@nifty.ne.jp>
2002-03-18 11:13:33 +00:00

55 lines
1.3 KiB
C

--- lib/converter.c.orig Sun Nov 26 22:10:22 2000
+++ lib/converter.c Mon Mar 18 19:49:56 2002
@@ -92,14 +92,14 @@
if (ch == UCS_CHAR_NONE) {
/* Incomplete character in input buffer */
errno = EINVAL;
- return res;
+ return (size_t)(-1);
}
if (ch == UCS_CHAR_INVALID) {
/* Invalid character in source buffer */
*inbytesleft += *inbuf - ptr;
*inbuf = ptr;
errno = EILSEQ;
- return res;
+ return (size_t)(-1);
}
size = ICONV_CES_CONVERT_FROM_UCS(&(uc->to), ch,
outbuf, outbytesleft);
@@ -116,7 +116,7 @@
*inbytesleft += *inbuf - ptr;
*inbuf = ptr;
errno = E2BIG;
- return res;
+ return (size_t)(-1);
}
}
return res;
@@ -156,14 +156,24 @@
{
if (inbuf && *inbuf && inbytesleft && *inbytesleft > 0 && outbuf
&& *outbuf && outbytesleft && *outbytesleft > 0) {
- size_t len = *inbytesleft < *outbytesleft ? *inbytesleft
- : *outbytesleft;
+ size_t result, len;
+ if (*inbytesleft < *outbytesleft) {
+ result = 0;
+ len = *inbytesleft;
+ } else {
+ result = (size_t)(-1);
+ errno = E2BIG;
+ len = *outbytesleft;
+ }
bcopy(*inbuf, *outbuf, len);
*inbuf += len;
*inbytesleft -= len;
*outbuf += len;
*outbytesleft -= len;
+
+ return result;
}
+
return 0;
}