X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/tripe/blobdiff_plain/ef4a1ab72d88f8790c367b513863d4f9a101a34d..602cab72ea5bce19bebb170ca0344404a963d022:/configure.in diff --git a/configure.in b/configure.in index 38fb539c..cb6efb2c 100644 --- a/configure.in +++ b/configure.in @@ -1,6 +1,6 @@ dnl -*-autoconf-*- dnl -dnl $Id: configure.in,v 1.14 2003/11/29 23:49:32 mdw Exp $ +dnl $Id$ dnl dnl Configuration script for TrIPE dnl @@ -25,57 +25,43 @@ dnl You should have received a copy of the GNU General Public License dnl along with TrIPE; if not, write to the Free Software Foundation, dnl Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -dnl ----- Revision history -------------------------------------------------- -dnl -dnl $Log: configure.in,v $ -dnl Revision 1.14 2003/11/29 23:49:32 mdw -dnl Debianization. -dnl -dnl Revision 1.13 2003/10/15 09:30:18 mdw -dnl Add support for Ethereal protocol analysis. -dnl -dnl Revision 1.12 2003/07/13 11:54:40 mdw -dnl Version bump. -dnl -dnl Revision 1.11 2003/05/17 11:04:38 mdw -dnl Ship new configuration and startup kit. -dnl -dnl Revision 1.9 2003/04/06 10:33:31 mdw -dnl And again. (Sigh.) -dnl -dnl Revision 1.8 2003/04/06 10:31:13 mdw -dnl Fix stupid bug. -dnl -dnl Revision 1.7 2003/04/06 10:25:17 mdw -dnl Support Linux TUN/TAP device. Fix some bugs. -dnl -dnl Revision 1.6 2001/06/19 22:13:57 mdw -dnl Version bump. -dnl -dnl Revision 1.5 2001/03/03 12:30:39 mdw -dnl Make this a pre-release. -dnl -dnl Revision 1.4 2001/02/22 09:07:28 mdw -dnl Build documents now. -dnl -dnl Revision 1.3 2001/02/16 21:24:12 mdw -dnl Don't link the client against Catacomb. -dnl -dnl Revision 1.2 2001/02/04 01:17:54 mdw -dnl Create a configuration header file to tidy up command lines. -dnl -dnl Revision 1.1 2001/02/03 20:26:37 mdw -dnl Initial checkin. -dnl - -AC_INIT(tripe.c) -AM_INIT_AUTOMAKE(tripe, 1.0.0pre6) -AM_CONFIG_HEADER(config.h) +AC_INIT(server/tripe.c) +AM_INIT_AUTOMAKE(tripe, 1.0.0pre7) +AM_CONFIG_HEADER(common/config.h) AC_CANONICAL_HOST AC_PROG_MAKE_SET AC_PROG_CC AM_PROG_LIBTOOL +DIRS="" AC_SUBST([DIRS]) + +python=no +mdw_PROG_PYTHON([2.3], + [python=yes + pyscripts='${PYTHONSCRIPTS}' + DIRS="$DIRS keys" + pymans='${PYTHONMANS}']) +AC_SUBST([pyscripts]) AC_SUBST([pymans]) + +if test $python = yes; then + mdw_CHECK_PYTHON([2.3]) + AC_CACHE_CHECK([for pygtk], [mdw_cv_pygtk], [ + mdw_cv_pygtk=no + python -c >&5 2>&5 ' +import pygtk +pygtk.require("2.0") +import gtk +' && mdw_cv_pygtk=yes + ]) + if test $mdw_cv_pygtk = yes; then + pygtkscripts='${PYGTKSCRIPTS}' + DIRS="$DIRS mon" + pygtkmans='${PYGTKMANS}' + fi +fi +AC_SUBST([pygtkscripts]) AC_SUBST([pygtkmans]) + +AC_CHECK_HEADERS([stdarg.h]) mdw_GCC_FLAGS([-Wall]) mdw_OPT_TRACE @@ -114,152 +100,166 @@ AC_ARG_WITH([logfile], [logfile=$withval], [logfile=tripe.log]) -DIRS="" -ETHEREAL_CFLAGS="" -ETHEREAL_PLUGIN_DIR="unknown" -AC_ARG_WITH([ethereal], -[ --with-ethereal build and install Ethereal plugin], +WIRESHARK_CFLAGS="" +WIRESHARK_PLUGIN_DIR="unknown" +AC_ARG_WITH([wireshark], +[ --with-wireshark build and install Wireshark plugin], [case "$withval" in - no) ethereal=false requireethereal=false;; - yes) ethereal=true; requireethereal=true;; - *) ethereal=true requireethereal=true ETHEREAL_PLUGIN_DIR=$withval;; + no) wireshark=false requirewireshark=false;; + yes) wireshark=true; requirewireshark=true;; + *) wireshark=true requirewireshark=true WIRESHARK_PLUGIN_DIR=$withval;; esac], -[ethereal=true requireethereal=false]) +[wireshark=true requirewireshark=false]) -case $host_os in - linux*) - case `uname -r` in +tun=auto +AC_ARG_WITH([tunnel], +[ --with-tunnel=KIND kinds of tunnel device to use + (linux, unet, bsd, slip)], +[tun=$withval]) + +if test "$tun" = auto; then + AC_CACHE_CHECK([tunnel drivers to use], [mdw_cv_tunnel], [ + mdw_cv_tunnel="" + case $host_os in + linux*) + case `uname -r` in changequote(,)dnl - 2.[4-9].* | 2.[1-9][0-9]*.* | [3-9].* | [1-9][0-9]*.*) + 2.[4-9].* | 2.[1-9][0-9]*.* | [3-9].* | [1-9][0-9]*.*) changequote([,])dnl - tun=linux - AC_DEFINE([TUN_TYPE], [TUN_LINUX]) + mdw_cv_tunnel=linux + ;; + *) + mdw_cv_tunnel=unet + ;; + esac ;; - *) - tun=unet - AC_DEFINE([TUN_TYPE], [TUN_UNET]) + *bsd*) + mdw_cv_tunnel=bsd ;; esac - ;; - *bsd*) - tun=bsd - AC_DEFINE([TUN_TYPE], [TUN_BSD]) - ;; - *) - AC_MSG_ERROR([Unsupported OS: no tunnel interface available]) - ;; -esac + mdw_cv_tunnel=$mdw_cv_tunnel${mdw_cv_tunnel:+ }slip + ]) + tun=$mdw_cv_tunnel +fi + +tunnels="" +for i in $tun; do + case $i in + linux) AC_DEFINE([TUN_LINUX], [1], + [Install the Linux TUN/TAP driver.]) ;; + bsd) AC_DEFINE([TUN_BSD], [1], + [Install the BSD tunnel driver.]) ;; + unet) AC_DEFINE([TUN_UNET], [1], + [Install the obsolete Linux Usernet driver.]) ;; + slip) ;; + *) AC_MSG_ERROR([Unknown tunnel type]) ;; + esac + tunnels="$tunnels&tun_$i, " +done AC_SUBST(tun) +AC_DEFINE_UNQUOTED([TUN_LIST], [$tunnels 0], + [List of tunnel drivers to install.]) mdw_MLIB(2.0.0) -mdw_CATACOMB(2.0.1, [CFLAGS="$CFLAGS $CATACOMB_CFLAGS"]) +mdw_CATACOMB(2.1.0, [CFLAGS="$CFLAGS $CATACOMB_CFLAGS"]) -if test "$ethereal" = true -a "$ETHEREAL_PLUGIN_DIR" = unknown; then - AC_CACHE_CHECK([where to put Ethereal plugins], - [mdw_cv_ethereal_plugin_dir], [ +if test "$wireshark" = true -a "$WIRESHARK_PLUGIN_DIR" = unknown; then + AC_CACHE_CHECK([where to put Wireshark plugins], + [mdw_cv_wireshark_plugin_dir], [ changequote(,) - mdw_cv_ethereal_plugin_dir="failed" - ethprefix=none + mdw_cv_wireshark_plugin_dir="failed" + wsprefix=none for i in "${prefix}" /usr/local /usr `echo $PATH | tr : " "`; do - if test -x "$i/bin/ethereal"; then - ethprefix=$i + if test -x "$i/bin/tshark"; then + wsprefix=$i break fi done - if test "$ethprefix" != none; then - ethbin=$ethprefix/bin/ethereal - ethver=`$ethbin -v | sed 's/^[^ ]* \([0-9A-Za-z.]*\).*$/\1/'` - dir=$ethprefix/lib/ethereal/plugins/$ethver + if test "$wsprefix" != none; then + wsbin=$wsprefix/bin/tshark + wsver=`$wsbin -v | sed 's/^[^ ]* \([0-9A-Za-z.]*\).*$/\1/;q'` + dir=$wsprefix/lib/wireshark/plugins/$wsver if test -d "$dir"; then - mdw_cv_ethereal_plugin_dir=$dir + mdw_cv_wireshark_plugin_dir=$dir fi fi changequote([, ]) ]) - case $mdw_cv_ethereal_plugin_dir in - failed) ethereal=false;; - *) ETHEREAL_PLUGIN_DIR=$mdw_cv_ethereal_plugin_dir;; + case $mdw_cv_wireshark_plugin_dir in + failed) wireshark=false;; + *) WIRESHARK_PLUGIN_DIR=$mdw_cv_wireshark_plugin_dir;; esac fi -if test "$ethereal" = true; then - AM_PATH_GLIB([1.2.0], [], ethereal=false, [gmodule]) +if test "$wireshark" = true; then + AM_PATH_GLIB([1.2.0], [], wireshark=false, [gmodule]) fi -if test "$ethereal" = true; then +if test "$wireshark" = true; then bad=true mdw_CFLAGS=$CFLAGS - ethprefix=`echo $ETHEREAL_PLUGIN_DIR | sed 's:/lib/.*$::'` - AC_CACHE_CHECK([how to find the Ethereal headers], - [mdw_cv_ethereal_includes], [ - mdw_cv_ethereal_includes=failed + wsprefix=`echo $WIRESHARK_PLUGIN_DIR | sed 's:/lib/.*$::'` + AC_CACHE_CHECK([how to find the Wireshark headers], + [mdw_cv_wireshark_includes], [ + mdw_cv_wireshark_includes=failed for i in \ "" \ - "-I${ethprefix}/include/ethereal" \ - "-I${ethprefix}/include" \ - "-I${prefix}/include/ethereal" \ + "-I${wsprefix}/include/wireshark" \ + "-I${wsprefix}/include" \ + "-I${prefix}/include/wireshark" \ "-I${prefix}/include" \ - "-I/usr/include/ethereal" \ - "-I/usr/local/include/ethereal" \ + "-I/usr/include/wireshark" \ + "-I/usr/local/include/wireshark" \ "-I/usr/local/include"; do CFLAGS="$GLIB_CFLAGS $i" AC_TRY_COMPILE([ #include #include -#include +#include +#include ], [ dissector_handle_t dh; - dh = creat_dissector_handle(0, 0); + dh = create_dissector_handle(0, 0); ], [bad=false; break]) done if test $bad = false; then - mdw_cv_ethereal_includes=$i + mdw_cv_wireshark_includes=$i fi CFLAGS=$mdw_CFLAGS ]) - case $mdw_cv_ethereal_plugin_dir in - failed) ethereal=false;; - *) ETHEREAL_PLUGIN_DIR=$mdw_cv_ethereal_plugin_dir;; + case $mdw_cv_wireshark_includes in + failed) wireshark=false;; esac fi -if test "$ethereal" = true; then - AC_CACHE_CHECK([whether the Ethereal headers are broken], - [mdw_cv_ethereal_buggered], [ - CFLAGS="$GLIB_CFLAGS $i" - AC_TRY_COMPILE([ -#include -#include -#include -#include -], [ - G_MODULE_EXPORT void plugin_init(plugin_address_table_t *pat) - { - plugin_address_table_init(pat); - } - ], [mdw_cv_ethereal_buggered=no], [mdw_cv_ethereal_buggered=yes]) - CFLAGS=$mdw_CFLAGS - ]) - if test $mdw_cv_ethereal_buggered = yes; then - AC_DEFINE(ETHEREAL_BUGGERED) - fi - - ETHEREAL_CFLAGS="$CFLAGS $GLIB_CFLAGS $mdw_cv_ethereal_includes" - AC_SUBST(ETHEREAL_CFLAGS) - AC_SUBST(ETHEREAL_PLUGIN_DIR) - DIRS="$DIRS ethereal" +if test "$wireshark" = true; then + WIRESHARK_CFLAGS="$CFLAGS $GLIB_CFLAGS $mdw_cv_wireshark_includes" + AC_SUBST(WIRESHARK_CFLAGS) + AC_SUBST(WIRESHARK_PLUGIN_DIR) + DIRS="$DIRS wireshark" fi -if test "$ethereal" = false -a "$requireethereal" = true; then - AC_MSG_ERROR([failed to configure Ethereal plugin]) +if test "$wireshark" = false -a "$requirewireshark" = true; then + AC_MSG_ERROR([failed to configure Wireshark plugin]) fi +AH_TEMPLATE([CONFIGDIR], + [Tripe should look here for keys and other configuration.]) +AH_TEMPLATE([SOCKETDIR], + [Tripe should make its administration socket here.]) mdw_DEFINE_PATHS([ mdw_DEFINE_PATH([CONFIGDIR], [$configdir]) mdw_DEFINE_PATH([SOCKETDIR], [$socketdir]) AC_SUBST(socketdir) AC_SUBST(configdir) AC_SUBST(logfile) AC_SUBST(pidfile) AC_SUBST(initconfig) ]) -AC_SUBST(DIRS) -AC_OUTPUT(Makefile doc/Makefile ethereal/Makefile tripe-init) +AC_OUTPUT( \ + Makefile \ + common/Makefile client/Makefile server/Makefile \ + proxy/Makefile pkstream/Makefile \ + doc/Makefile doc/tripe.8 doc/tripectl.1 \ + wireshark/Makefile \ + init/Makefile init/tripe-init \ + keys/Makefile keys/tripe-keys \ + mon/Makefile mon/tripemon) dnl ----- That's all, folks -------------------------------------------------