--- projects/libstatgrab/configure.in 2004/02/12 23:28:20 1.55 +++ projects/libstatgrab/configure.in 2006/12/01 14:21:16 1.91 @@ -2,15 +2,16 @@ # Process this file with autoconf to produce a configure script. # # configure.in for libstatgrab -# $Id: configure.in,v 1.55 2004/02/12 23:28:20 tdb Exp $ +# $Id: configure.in,v 1.91 2006/12/01 14:21:16 tdb Exp $ # # Change these to change the package name and version -AC_INIT(libstatgrab, 0.9, bugs@i-scream.org) -AM_INIT_AUTOMAKE(libstatgrab, 0.9) +AC_INIT(libstatgrab, 0.14, bugs@i-scream.org) +AM_INIT_AUTOMAKE(libstatgrab, 0.14) +AM_MAINTAINER_MODE # Revision number (automatically updated) -AC_REVISION($Revision: 1.55 $) +AC_REVISION($Revision: 1.91 $) # Might work with older autoconfs... but tested on 2.57 AC_PREREQ(2.57) @@ -31,15 +32,26 @@ AC_C_CONST # Checks for library functions AC_FUNC_MALLOC -AC_FUNC_REALLOC -AC_CHECK_FUNCS(atoll) +AC_CHECK_FUNCS(atoll seteuid setegid setresuid setresgid) # Disk IO read and write statistics are only present on recent NetBSD. AC_CHECK_MEMBER(struct disk_sysctl.dk_rbytes, - [AC_DEFINE(HAVE_DK_RBYTES, , [New-style NetBSD stats])], + [AC_DEFINE(HAVE_DK_RBYTES, , [New-style NetBSD disk stats])], [], [#include ]) +# Disk IO read and write statistics are only present on recent OpenBSD. +AC_CHECK_MEMBER(struct diskstats.ds_rbytes, + [AC_DEFINE(HAVE_DS_RBYTES, , [New-style OpenBSD disk stats])], + [], + [#include ]) + +# NetBSD 2.0 uses statvfs rather than statfs +AC_CHECK_MEMBER(struct statvfs.f_fstypename, + [AC_DEFINE(HAVE_STATVFS, , [NetBSD 2.0 statvfs])], + [], + [#include ]) + # Check for sys/loadavg.h AC_CHECK_HEADERS([sys/loadavg.h]) @@ -50,6 +62,9 @@ AC_CHECK_HEADERS([libdevinfo.h]) AM_CONDITIONAL(SETGIDBINS, false) AM_CONDITIONAL(SETUIDBINS, false) +# Default MINGW setting +AM_CONDITIONAL(MINGW, false) + # Set things up for different OS's # We define the name of the OS so the code can act accordingly # We also need to add the right LDFLAGS @@ -59,46 +74,69 @@ solaris2.[[6-7]]) AC_DEFINE(SOLARIS, , [Building on Solaris 2.x]) AC_DEFINE(SOL7, , [Building on Solaris 2.6 or 2.7]) AM_CONDITIONAL(SETUIDBINS, true) - LINKFLAGS="-lkstat" + BIN_OWNER="root" + BIN_PERM="4755" + LINKFLAGS="-lkstat -lsocket -lnsl" AC_CHECK_LIB(devinfo, di_init, [LINKFLAGS="$LINKFLAGS -ldevinfo"]) ;; solaris2.*) AC_CHECK_HEADERS([kstat.h],,[AC_MSG_ERROR([need kstat.h])]) AC_DEFINE(SOLARIS, , [Building on Solaris 2.x]) - AM_CONDITIONAL(SETUIDBINS, true) - LINKFLAGS="-lkstat -ldevinfo" + LINKFLAGS="-lkstat -ldevinfo -lsocket -lnsl" ;; +hpux11.11*) + AC_DEFINE(HPUX, , [Building on HP-UX 11.11]) + ;; freebsd4.*) AC_DEFINE(ALLBSD, , [Building on a BSD-derived system]) AC_DEFINE(FREEBSD, , [Building on FreeBSD]) AM_CONDITIONAL(SETGIDBINS, true) + BIN_GROUP="kmem" + BIN_PERM="2755" LINKFLAGS="-lkvm -ldevstat" ;; -freebsd5.*) +freebsd[[5-7]].*) AC_DEFINE(ALLBSD, , [Building on a BSD-derived system]) AC_DEFINE(FREEBSD, , [Building on FreeBSD]) - AC_DEFINE(FREEBSD5, , [Building on FreeBSD 5.x]) - AM_CONDITIONAL(SETGIDBINS, true) - LINKFLAGS="-lkvm -ldevstat" + AC_DEFINE(FREEBSD5, , [Building on FreeBSD 5.x - 7.x]) + LINKFLAGS="-ldevstat" ;; -netbsdelf*) +netbsdelf1*) AC_DEFINE(ALLBSD, , [Building on a BSD-derived system]) AC_DEFINE(NETBSD, , [Building on NetBSD]) - AM_CONDITIONAL(SETGIDBINS, true) - LINKFLAGS="-lkvm" ;; +netbsdelf[[2-3]]*) + AC_DEFINE(ALLBSD, , [Building on a BSD-derived system]) + AC_DEFINE(NETBSD, , [Building on NetBSD]) + AC_DEFINE(NETBSD2, , [Building on NetBSD 2.x]) + ;; openbsd*) AC_DEFINE(ALLBSD, , [Building on a BSD-derived system]) AC_DEFINE(OPENBSD, , [Building on OpenBSD]) + ;; +dragonfly*) + AC_DEFINE(ALLBSD, , [Building on a BSD-derived system]) + AC_DEFINE(DFBSD, , [Building on DragonFlyBSD]) AM_CONDITIONAL(SETGIDBINS, true) - LINKFLAGS="-lkvm" + BIN_GROUP="kmem" + BIN_PERM="2755" + LINKFLAGS="-lkvm -ldevstat" ;; linux-gnu) AC_DEFINE(LINUX, , [Building on GNU/Linux]) + AM_CONDITIONAL(SETUIDBINS, true) + BIN_OWNER="root" + BIN_PERM="4755" ;; cygwin) AC_DEFINE(CYGWIN, , [Building on Cygwin]) ;; +mingw32) + AC_DEFINE(MINGW, , [Building on MinGW]) + AC_DEFINE(WINVER, 0x0500, [Building for Windows 2000]) + AM_CONDITIONAL(MINGW, true) + LINKFLAGS="-lpdh -lIphlpapi -lpsapi -lnetapi32" + ;; *) AC_MSG_ERROR([Cannot build on unknown OS: $host_os]) ;; @@ -112,7 +150,7 @@ AC_ARG_WITH([curses-prefix], SAIDARLIBS="-L${withval}/lib ${SAIDARLIBS}" fi if test -d "$withval/include"; then - SAIDARCPPFLAGS="-I${withval}/include -I${withval}/include/ncurses ${SAIRDARCPPFLAGS}" + SAIDARCPPFLAGS="-I${withval}/include ${SAIRDARCPPFLAGS}" fi ] ) @@ -186,6 +224,17 @@ AC_ARG_ENABLE(setuid-binaries, ] ) +# Check if the user would prefer not to include compatibility code +AM_CONDITIONAL(DEPRECATED, true) +AC_ARG_ENABLE(deprecated, + [ --disable-deprecated disable inclusion of pre-0.10 compatibility code], + [ + if test "x$enableval" = "xno" ; then + AM_CONDITIONAL(DEPRECATED, false) + fi + ] +) + # The LIBS and CPPFLAGS that saidar needs AC_SUBST(SAIDARLIBS) AC_SUBST(SAIDARCPPFLAGS) @@ -194,7 +243,12 @@ AC_SUBST(SAIDARCPPFLAGS) # (ie. our dependencies) AC_SUBST(LINKFLAGS) +# Ownership and permissions possibly needed for binaries +AC_SUBST(BIN_OWNER) +AC_SUBST(BIN_GROUP) +AC_SUBST(BIN_PERM) + # And finish by changing these files -AC_CONFIG_FILES([Makefile src/Makefile src/libstatgrab/Makefile src/statgrab/Makefile docs/Makefile examples/Makefile libstatgrab.pc src/statgrab/statgrab-make-mrtg-config src/statgrab/statgrab-make-mrtg-index src/saidar/Makefile]) +AC_CONFIG_FILES([Makefile src/Makefile src/libstatgrab/Makefile src/statgrab/Makefile docs/Makefile docs/libstatgrab/Makefile docs/statgrab/Makefile docs/saidar/Makefile examples/Makefile libstatgrab.pc src/statgrab/statgrab-make-mrtg-config src/statgrab/statgrab-make-mrtg-index src/saidar/Makefile]) AC_OUTPUT