diff options
author | Andrew Tridgell <tridge@samba.org> | 2010-03-07 22:52:58 +1100 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2010-04-06 20:26:45 +1000 |
commit | df5dee4b71844325d62a53928c7341648ac2d362 (patch) | |
tree | 0a3db891015b990cd1f498af4a6eecddccea0ab5 | |
parent | 1958a0987e5aa252eac6bffd1b829eb1405b9591 (diff) | |
download | samba-df5dee4b71844325d62a53928c7341648ac2d362.tar.gz samba-df5dee4b71844325d62a53928c7341648ac2d362.tar.bz2 samba-df5dee4b71844325d62a53928c7341648ac2d362.zip |
build: more libreplace config checks
-rw-r--r-- | lib/replace/wscript | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/lib/replace/wscript b/lib/replace/wscript index d10a70342e..8f5e5fae9f 100644 --- a/lib/replace/wscript +++ b/lib/replace/wscript @@ -105,6 +105,12 @@ def configure(conf): conf.CHECK_TYPE_IN('struct ifaddrs', 'ifaddrs.h') conf.CHECK_TYPE_IN('struct addrinfo', 'netdb.h') conf.CHECK_TYPE_IN('struct sockaddr', 'sys/socket.h') + conf.CHECK_TYPE_IN('struct sockaddr_in6', 'sys/socket.h') + conf.CHECK_TYPE_IN('struct sockaddr_storage', 'sys/socket.h') + conf.CHECK_TYPE_IN('sa_family_t', 'sys/socket.h') + + conf.CHECK_TYPE_IN('sig_atomic_t', 'signal.h', define='HAVE_SIG_ATOMIC_T_TYPE') + conf.CHECK_FUNCS('shl_load shl_unload shl_findsym') conf.CHECK_FUNCS('pipe strftime srandom random srand rand usleep setbuffer') @@ -207,6 +213,37 @@ def configure(conf): ''', define='HAVE_IMMEDIATE_STRUCTURES') + conf.CHECK_CODE('mkdir("foo",0777)', define='HAVE_MKDIR_MODE') + + conf.CHECK_STRUCTURE_MEMBER('struct stat', 'st_mtim.tv_nsec', define='HAVE_STAT_TV_NSEC') + # we need the st_rdev test under two names + conf.CHECK_STRUCTURE_MEMBER('struct stat', 'st_rdev', define='HAVE_STRUCT_STAT_ST_RDEV') + conf.CHECK_STRUCTURE_MEMBER('struct stat', 'st_rdev', define='HAVE_ST_RDEV') + conf.CHECK_STRUCTURE_MEMBER('struct sockaddr_storage', 'ss_family') + + conf.CHECK_CODE('struct sockaddr_un sunaddr; sunaddr.sun_family = AF_UNIX;', + define='HAVE_UNIXSOCKET') + + + conf.CHECK_CODE(''' + struct stat st; + char tpl[20]="/tmp/test.XXXXXX"; + int fd = mkstemp(tpl); + if (fd == -1) exit(1); + unlink(tpl); + if (fstat(fd, &st) != 0) exit(1); + if ((st.st_mode & 0777) != 0600) exit(1); + exit(0); + ''', + define='HAVE_SECURE_MKSTEMP', + execute=True, + mandatory=True) # lets see if we get a mandatory failure for this one + + if conf.CHECK_CFLAGS('-fvisibility=hidden', 'VISIBILITY_CFLAGS'): + conf.CHECK_CODE('''void vis_foo1(void) {} + __attribute__((visibility("default"))) void vis_foo2(void) {}''', + cflags=conf.env.VISIBILITY_CFLAGS, + define='HAVE_VISIBILITY_ATTR') def build(bld): |