X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2FOS%2Fos.h-FreeBSD;h=bf43e0a3cec0415c6681db719e063a2e5b9cd89a;hb=45f35410b4bdd59614dd9811ee99aea6a5d1164c;hp=091089f52ccc53f90a4ce162717d60b3c2500c0d;hpb=929ba01ccb7fafbe89e4fa60e93ab2b5f4aab1df;p=user%2Fhenk%2Fcode%2Fexim.git diff --git a/src/OS/os.h-FreeBSD b/src/OS/os.h-FreeBSD index 091089f52..bf43e0a3c 100644 --- a/src/OS/os.h-FreeBSD +++ b/src/OS/os.h-FreeBSD @@ -1,13 +1,37 @@ -/* $Cambridge: exim/src/OS/os.h-FreeBSD,v 1.2 2006/02/21 16:24:19 ph10 Exp $ */ - /* Exim: OS-specific C header file for FreeBSD */ #define HAVE_BSD_GETLOADAVG -#define HAVE_LOGIN_CAP +#define HAVE_SETCLASSRESOURCES #define HAVE_MMAP #define HAVE_SYS_MOUNT_H #define SIOCGIFCONF_GIVES_ADDR +#define HAVE_SRANDOMDEV +#define HAVE_ARC4RANDOM typedef struct flock flock_t; +/* iconv arg2 type: libiconv in Ports uses "const char* * inbuf" and was + * traditionally the only approach available. The iconv functionality + * in libc is "char ** restrict src". + * + * + * says that libc has iconv since 2013, in 10-CURRENT. FreeBSD man-pages + * shows it included in 10.0-RELEASE. Writing this in 2017, 10.3 is the + * oldest supported release, so we should assume non-libiconv by default. + * (Actually, people still using old releases past EOL; we shouldn't support + * them but I don't want to deal with howls of complaints because we dare + * to not support the unsupported, so guard this on FreeBSD 10+) + * + * Thus we no longer override iconv. + * + * However, if libiconv is installed, and anything adds /usr/local/include + * to include-path (likely) then we'll get that. So define a variable + * which makes the libiconv try to not interfere with OS iconv. + */ +#if __FreeBSD__ >= 10 +# define LIBICONV_PLUG +#endif +/* for more specific version constraints, include and look at + * __FreeBSD_version */ + /* End */