Lets us configure and build on FreeBSD
This commit is contained in:
ridiculousfish 2012-07-10 15:37:16 -07:00
parent 6f0b00f983
commit 176a3913aa
2 changed files with 31 additions and 3 deletions

View file

@ -104,8 +104,9 @@ fi
# This mostly helps OS X users, since fink usually installs out of # This mostly helps OS X users, since fink usually installs out of
# tree and doesn't update CFLAGS. # tree and doesn't update CFLAGS.
# #
# It also helps FreeBSD which puts libiconv in /usr/local/lib
for i in /usr/pkg /sw /opt /opt/local; do for i in /usr/pkg /sw /opt /opt/local /usr/local; do
AC_MSG_CHECKING([for $i/include include directory]) AC_MSG_CHECKING([for $i/include include directory])
if test -d $i/include; then if test -d $i/include; then

View file

@ -167,6 +167,26 @@ static const char *iconv_wide_names_2[]=
} }
; ;
template<class T>
class sloppy {};
static size_t hack_iconv(iconv_t cd, const char * const* inbuf, size_t *inbytesleft, char **outbuf, size_t *outbytesleft)
{
/* FreeBSD has this prototype: size_t iconv (iconv_t, const char **...)
OS X and Linux this one: size_t iconv (iconv_t, char **...)
AFAIK there's no single type that can be passed as both char ** and const char **.
Therefore, we let C++ figure it out, by providing a struct with an implicit conversion to both char** and const char **.
*/
struct sloppy_char
{
const char * const * t;
operator char** () const { return (char **)t; }
operator const char** () const { return (const char**)t; }
} slop_inbuf = {inbuf};
return iconv( cd, slop_inbuf, inbytesleft, outbuf, outbytesleft );
}
/** /**
Convert utf-8 string to wide string Convert utf-8 string to wide string
*/ */
@ -246,7 +266,12 @@ static wchar_t *utf2wcs( const char *in )
return 0; return 0;
} }
nconv = iconv( cd, (char **)&in, &in_len, &nout, &out_len ); /* FreeBSD has this prototype: size_t iconv (iconv_t, const char **...)
OS X and Linux this one: size_t iconv (iconv_t, char **...)
AFAIK there's no single type that can be passed as both char ** and const char **.
So we cast the function pointer instead (!)
*/
nconv = hack_iconv( cd, &in, &in_len, &nout, &out_len );
if (nconv == (size_t) -1) if (nconv == (size_t) -1)
{ {
@ -280,6 +305,8 @@ static wchar_t *utf2wcs( const char *in )
return out; return out;
} }
/** /**
Convert wide string to utf-8 Convert wide string to utf-8
*/ */
@ -357,7 +384,7 @@ static char *wcs2utf( const wchar_t *in )
return 0; return 0;
} }
nconv = iconv( cd, &char_in, &in_len, &nout, &out_len ); nconv = hack_iconv( cd, &char_in, &in_len, &nout, &out_len );
if (nconv == (size_t) -1) if (nconv == (size_t) -1)