diff options
| -rw-r--r-- | Makefile | 7 | ||||
| -rw-r--r-- | utf8.c | 10 | 
2 files changed, 15 insertions, 2 deletions
| @@ -89,6 +89,9 @@ all::  #  # Define NO_ICONV if your libc does not properly support iconv.  # +# Define OLD_ICONV if your library has an old iconv(), where the second +# (input buffer pointer) parameter is declared with type (const char **). +#  # Define NO_R_TO_GCC if your gcc does not like "-R/path/lib" that  # tells runtime paths to dynamic libraries; "-Wl,-rpath=/path/lib"  # is used instead. @@ -573,6 +576,10 @@ ifdef NO_ICONV  	BASIC_CFLAGS += -DNO_ICONV  endif +ifdef OLD_ICONV +	BASIC_CFLAGS += -DOLD_ICONV +endif +  ifdef PPC_SHA1  	SHA1_HEADER = "ppc/sha1.h"  	LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o @@ -293,11 +293,17 @@ int is_encoding_utf8(const char *name)   * with iconv.  If the conversion fails, returns NULL.   */  #ifndef NO_ICONV +#ifdef OLD_ICONV +	typedef const char * iconv_ibp; +#else +	typedef char * iconv_ibp; +#endif  char *reencode_string(const char *in, const char *out_encoding, const char *in_encoding)  {  	iconv_t conv;  	size_t insz, outsz, outalloc; -	char *out, *outpos, *cp; +	char *out, *outpos; +	iconv_ibp cp;  	if (!in_encoding)  		return NULL; @@ -309,7 +315,7 @@ char *reencode_string(const char *in, const char *out_encoding, const char *in_e  	outalloc = outsz + 1; /* for terminating NUL */  	out = xmalloc(outalloc);  	outpos = out; -	cp = (char *)in; +	cp = (iconv_ibp)in;  	while (1) {  		size_t cnt = iconv(conv, &cp, &insz, &outpos, &outsz); | 
