06bb167824
(emem alignment problems on SPARC) : Have emem use 8-byte alignment when we need it. Since I can't seem to write code that which reliably (across GCC versions and optimization levels) determines if 8-byte alignment is needed for doubles, "when" is defined as "if we're compiling for a CPU other than i386." Windows doesn't need a check because it's either i386 or 64-bit (x86_64 or maybe ia64--both of which get 8-byte alignment from G_MEM_ALIGN). (And, yes, all of this is ignoring the 16-byte alignment requirements of long doubles.) svn path=/trunk/; revision=42431
2251 lines
62 KiB
Text
2251 lines
62 KiB
Text
# $Id$
|
|
#
|
|
AC_PREREQ(2.60)
|
|
|
|
AC_INIT(wireshark, 1.7.2)
|
|
|
|
dnl Check for CPU / vendor / OS
|
|
dnl The user is encouraged to use either `AC_CANONICAL_BUILD', or
|
|
dnl `AC_CANONICAL_HOST', or `AC_CANONICAL_TARGET', depending on the
|
|
dnl needs. Using `AC_CANONICAL_TARGET' is enough to run the two other
|
|
dnl macros.
|
|
dnl
|
|
dnl As nothing in the Wireshark is itself a build tool (we are not,
|
|
dnl for example, a compiler that generates machine code), we probably
|
|
dnl don't need AC_CANONICAL_TARGET, so, in theory, we should be able
|
|
dnl to use AC_CANONICAL_BUILD and AC_CANONICAL_HOST - or perhaps just
|
|
dnl AC_CANONICAL_HOST - instead. Note that we do have tools, such as
|
|
dnl lemon, that need to be built for the build machine, not for the
|
|
dnl host machine, so we might need both.
|
|
dnl
|
|
dnl This has to be done *after* AC_INIT, otherwise autogen.sh fails.
|
|
|
|
dnl AC_CANONICAL_BUILD
|
|
dnl AC_CANONICAL_HOST
|
|
AC_CANONICAL_TARGET
|
|
|
|
AM_INIT_AUTOMAKE([1.9 tar-ustar dist-bzip2 no-dist-gzip])
|
|
|
|
AM_DISABLE_STATIC
|
|
|
|
dnl Checks for programs.
|
|
AC_PROG_CC
|
|
AM_PROG_CC_C_O
|
|
AC_PROG_CXX
|
|
AC_PROG_CPP
|
|
dnl Work around libtool bug (fixed in the version 1.5a?)
|
|
AC_DEFUN([AC_PROVIDE_AC_LIBTOOL_DLOPEN], )
|
|
AC_LIBTOOL_DLOPEN
|
|
AC_PROG_LIBTOOL
|
|
AC_PATH_PROG(PERL, perl)
|
|
#
|
|
# XXX - should autogen.sh check for YACC/Bison and Flex? A user building
|
|
# from a distribution tarball shouldn't have to have YACC/Bison or Flex,
|
|
# as the tarball should contain the results of running YACC/Bison on .y
|
|
# files and running Flex on .l files, but a user building from SVN
|
|
# will have to run YACC/Bison and Flex to process those files.
|
|
#
|
|
# On the other hand, what about users who use a distribution tarball to
|
|
# do development? They *shouldn't* - that's what the SVN repository is
|
|
# for - but they might. They'd get errors if they modify a .y or .l
|
|
# file and try to do a build - but the error should tell them that they
|
|
# need to get YACC/Bison and/or Flex.
|
|
#
|
|
# Then again, getting them shouldn't be too big of a burden.
|
|
#
|
|
# XXX - is the same true of pod2man and pod2html, or are they needed
|
|
# even when building from a distribution tarball?
|
|
#
|
|
#
|
|
AC_PROG_YACC
|
|
AC_PATH_PROG(YACCDUMMY, $YACC)
|
|
if test "x$YACCDUMMY" = x
|
|
then
|
|
AC_MSG_ERROR(I couldn't find yacc (or bison or ...); make sure it's installed and in your path)
|
|
fi
|
|
AM_PROG_LEX
|
|
AC_PATH_PROG(LEX, flex)
|
|
if test "x$LEX" = x
|
|
then
|
|
AC_MSG_ERROR(I couldn't find flex; make sure it's installed and in your path)
|
|
fi
|
|
AC_PATH_PROG(POD2MAN, pod2man)
|
|
if test "x$POD2MAN" = x
|
|
then
|
|
#
|
|
# The alternative is not to build the man pages....
|
|
#
|
|
AC_MSG_ERROR(I couldn't find pod2man; make sure it's installed and in your path)
|
|
fi
|
|
AC_PATH_PROG(POD2HTML, pod2html)
|
|
if test "x$POD2HTML" = x
|
|
then
|
|
#
|
|
# The alternative is not to build the HTML man pages....
|
|
#
|
|
AC_MSG_ERROR(I couldn't find pod2html; make sure it's installed and in your path)
|
|
fi
|
|
|
|
#
|
|
# XXX - this looks for various HTML viewers on the host, not the target;
|
|
# we really want to know what's available on the target, for cross-builds.
|
|
# That would probably require us to, at run time, look for xdg-open and,
|
|
# if we don't find it, look for mozilla, htmlview, etc.
|
|
#
|
|
AC_PATH_PROG(HTML_VIEWER, xdg-open)
|
|
if test "x$HTML_VIEWER" != x
|
|
then
|
|
#
|
|
# XXX - the HTML_VIEWER shell variable is the full path of xdg-open.
|
|
# Define some variable to be that, so we just run that?
|
|
#
|
|
AC_DEFINE(HAVE_XDG_OPEN, 1, [Define if we have xdg-open])
|
|
|
|
#
|
|
# XXX - we have to define HTML_VIEWER for the prefs.c code that
|
|
# sets the default value of the Web browser preference, even
|
|
# though that preference won't be offered.
|
|
#
|
|
AC_DEFINE_UNQUOTED(HTML_VIEWER, "xdg-open", [HTML viewer, e.g. mozilla])
|
|
else
|
|
AC_PATH_PROG(HTML_VIEWER, htmlview)
|
|
if test "x$HTML_VIEWER" = x
|
|
then
|
|
AC_DEFINE_UNQUOTED(HTML_VIEWER, "mozilla", [HTML viewer, e.g. mozilla])
|
|
else
|
|
AC_DEFINE_UNQUOTED(HTML_VIEWER, "htmlview", [HTML viewer, e.g. mozilla])
|
|
fi
|
|
fi
|
|
|
|
AC_PATH_PROG(PYTHON, python)
|
|
|
|
AC_SUBST(PERL)
|
|
AC_SUBST(LEX)
|
|
AC_SUBST(POD2MAN)
|
|
AC_SUBST(POD2HTML)
|
|
AC_SUBST(PYTHON)
|
|
AC_SUBST(XSLTPROC)
|
|
AC_SUBST(XMLLINT)
|
|
|
|
#
|
|
# Set "ac_supports_gcc_flags" if the compiler is known to support GCC-style
|
|
# flags such as -pedantic, -W warning flags and -f feature flags. Currently,
|
|
# we assume GCC and clang do; other compilers should be added here.
|
|
#
|
|
# This is done to avoid getting tripped up by compilers that support
|
|
# those flags but give them a different meaning.
|
|
#
|
|
if test "x$GCC" = "xyes" -o "x$CC" = "xclang" ; then
|
|
ac_supports_gcc_flags=yes
|
|
fi
|
|
|
|
#
|
|
# Set "ac_supports_W_linker_passthrough" if the compiler is known to
|
|
# support "-Wl,{options}" to pass options through to the linker.
|
|
# Currently, we assume GCC, xlc, and clang do; other compilers should
|
|
# be added here.
|
|
#
|
|
if test "x$GCC" = "xyes" -o "x$CC" = "xxlc" -o "x$CC" = "xclang" ; then
|
|
ac_supports_W_linker_passthrough=yes
|
|
fi
|
|
|
|
#
|
|
# Set "ac_supports_attribute_unused" if the compiler is known to
|
|
# support "__attribute__(unused)".
|
|
# Currently, we assume GCC and clang do; other compilers should
|
|
# be added here.
|
|
#
|
|
# XXX - do this with a compiler test?
|
|
#
|
|
if test "x$GCC" = "xyes" -o "x$CC" = "xclang" ; then
|
|
ac_supports_W_linker_passthrough=yes
|
|
fi
|
|
|
|
if test "x$CC_FOR_BUILD" = x
|
|
then
|
|
CC_FOR_BUILD=$CC
|
|
fi
|
|
AC_SUBST(CC_FOR_BUILD)
|
|
|
|
# Check for doxygen
|
|
AC_PATH_PROG(DOXYGEN, doxygen)
|
|
AC_CHECK_PROG(HAVE_DOXYGEN, doxygen, "yes", "no")
|
|
AM_CONDITIONAL(HAVE_DOXYGEN, test x$HAVE_DOXYGEN = xyes)
|
|
|
|
#
|
|
# Try to arrange for large file support.
|
|
#
|
|
AC_SYS_LARGEFILE
|
|
|
|
# GnuTLS
|
|
# Version 3.0 switched from LGPLv2.1+ to LGPLv3+.
|
|
tls_message="no"
|
|
AC_ARG_WITH([gnutls],
|
|
AC_HELP_STRING( [--with-gnutls=@<:@yes/no@:>@],
|
|
[use GnuTLS library @<:@default=yes@:>@]),
|
|
with_gnutls="$withval", with_gnutls="yes")
|
|
if test "x$with_gnutls" = "xyes"; then
|
|
PKG_CHECK_MODULES([LIBGNUTLS], [gnutls >= 1.2.0 gnutls < 3],
|
|
[
|
|
echo "GnuTLS found, enabling SSL decryption"
|
|
AC_DEFINE(HAVE_LIBGNUTLS, 1, [Define to use GnuTLS library])
|
|
tls_message="yes"
|
|
]
|
|
, [
|
|
echo "GnuTLS not found, disabling SSL decryption"
|
|
tls_message="no"
|
|
]
|
|
)
|
|
fi
|
|
|
|
# libgrypt
|
|
gcrypt_message="no"
|
|
AC_ARG_WITH([gcrypt],
|
|
AC_HELP_STRING( [--with-gcrypt=@<:@yes/no@:>@],
|
|
[use gcrypt library @<:@default=yes@:>@]),
|
|
with_gcrypt="$withval", with_gcrypt="yes")
|
|
if test "x$with_gcrypt" = "xyes"; then
|
|
AM_PATH_LIBGCRYPT(1.1.92,
|
|
[
|
|
echo "libgcrypt found, enabling ipsec decryption"
|
|
AC_DEFINE(HAVE_LIBGCRYPT, 1, [Define to use libgcrypt])
|
|
gcrypt_message="yes"
|
|
]
|
|
, [
|
|
if test x$libgcrypt_config_prefix != x ; then
|
|
AC_MSG_ERROR([[libgcrypt not found; install libgcrypt-devel package for your system]])
|
|
else
|
|
echo "libgcrypt not found, disabling ipsec decryption"
|
|
gcrypt_message="no"
|
|
fi
|
|
]
|
|
)
|
|
fi
|
|
|
|
AC_ARG_WITH([qt],
|
|
AC_HELP_STRING( [--with-qt=@<:@yes/no@:>@],
|
|
[use Qt instead of GTK+ @<:@default=no@:>@]),
|
|
with_qt="$withval", with_qt="no")
|
|
|
|
AC_ARG_WITH([gtk3],
|
|
AC_HELP_STRING( [--with-gtk3=@<:@yes/no@:>@],
|
|
[use GTK+ 3.0 instead of 2.0 @<:@default=no@:>@]),
|
|
with_gtk3="$withval", with_gtk3="no")
|
|
|
|
# libsmi
|
|
# FIXME: currently the path argument to with-libsmi is being ignored
|
|
AX_LIBSMI
|
|
|
|
# Check for xsltproc
|
|
AC_PATH_PROG(XSLTPROC, xsltproc)
|
|
AC_CHECK_PROG(HAVE_XSLTPROC, xsltproc, "yes", "no")
|
|
AM_CONDITIONAL(HAVE_XSLTPROC, test x$HAVE_XSLTPROC = xyes)
|
|
|
|
# Check for xmllint
|
|
AC_PATH_PROG(XMLLINT, xmllint)
|
|
AC_CHECK_PROG(HAVE_XMLLINT, xmllint, "yes", "no")
|
|
AM_CONDITIONAL(HAVE_XMLLINT, test x$HAVE_XMLLINT = xyes)
|
|
|
|
# Check for fop (translate .fo to e.g. pdf)
|
|
AC_PATH_PROG(FOP, fop)
|
|
AC_CHECK_PROG(HAVE_FOP, fop, "yes", "no")
|
|
AM_CONDITIONAL(HAVE_FOP, test x$HAVE_FOP = xyes)
|
|
|
|
#
|
|
# Look for something to convert HTML to text (for docbook/)
|
|
#
|
|
AC_PATH_PROG(ELINKS, elinks)
|
|
AC_CHECK_PROG(HAVE_ELINKS, elinks, "yes", "no")
|
|
AM_CONDITIONAL(HAVE_ELINKS, test x$HAVE_ELINKS = xyes)
|
|
|
|
## links: Fails as used in docbook/Makefile.am
|
|
## (Rather than fixing things we'll just disable the use of links).
|
|
##AC_PATH_PROG(LINKS, links)
|
|
##AC_CHECK_PROG(HAVE_LINKS, links, "yes", "no")
|
|
##AM_CONDITIONAL(HAVE_LINKS, test x$HAVE_LINKS = xyes)
|
|
|
|
AC_PATH_PROG(LYNX, lynx)
|
|
AC_CHECK_PROG(HAVE_LYNX, lynx, "yes", "no")
|
|
AM_CONDITIONAL(HAVE_LYNX, test x$HAVE_LYNX = xyes)
|
|
|
|
|
|
# Check for hhc (html help compiler)
|
|
AC_PATH_PROG(HHC, hhc.exe)
|
|
AC_CHECK_PROG(HAVE_HHC, hhc.exe, "yes", "no")
|
|
AM_CONDITIONAL(HAVE_HHC, test x$HAVE_HHC = xyes)
|
|
|
|
# Check for packaging utilities
|
|
# For now, we check to see if the various packaging utilites are in our
|
|
# path. I'm too lazy to write code to go hunt for them. - Gerald
|
|
|
|
# SVR4/Solaris
|
|
AC_CHECK_PROG(HAVE_PKGPROTO, pkgproto, "yes", "no")
|
|
AC_CHECK_PROG(HAVE_PKGMK, pkgmk, "yes", "no")
|
|
AC_CHECK_PROG(HAVE_PKGTRANS, pkgtrans, "yes", "no")
|
|
|
|
if test x$HAVE_PKGPROTO = xyes -a x$HAVE_PKGMK = xyes \
|
|
-a x$HAVE_PKGTRANS = xyes ; then
|
|
HAVE_SVR4_PACKAGING=yes
|
|
else
|
|
HAVE_SVR4_PACKAGING=no
|
|
fi
|
|
AC_SUBST(HAVE_SVR4_PACKAGING)
|
|
|
|
# RPM
|
|
AC_WIRESHARK_RPM_CHECK
|
|
AC_SUBST(HAVE_RPM)
|
|
|
|
# Debian
|
|
AC_CHECK_PROG(HAVE_DPKG_BUILDPACKAGE, dpkg-buildpackage, "yes", "no")
|
|
|
|
# Mac OS X
|
|
AC_CHECK_PROG(HAVE_XCODEBUILD, xcodebuild, "yes", "no")
|
|
AC_CHECK_PROG(HAVE_HDIUTIL, hdiutil, "yes", "no")
|
|
AC_CHECK_PROG(HAVE_BLESS, bless, "yes", "no")
|
|
|
|
if test x$HAVE_XCODEBUILD = xyes -a x$HAVE_HDIUTIL = xyes \
|
|
-a x$HAVE_BLESS = xyes ; then
|
|
HAVE_OSX_PACKAGING=yes
|
|
else
|
|
HAVE_OSX_PACKAGING=no
|
|
fi
|
|
AC_SUBST(HAVE_OSX_PACKAGING)
|
|
|
|
#
|
|
# Try to add some additional gcc checks to CFLAGS
|
|
#
|
|
AC_ARG_ENABLE(extra-gcc-checks,
|
|
AC_HELP_STRING( [--enable-extra-gcc-checks],
|
|
[do additional -W checks in GCC @<:@default=no@:>@]),
|
|
[
|
|
wireshark_extra_gcc_flags=$enableval
|
|
if test $enableval != no
|
|
then
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-pedantic)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Woverflow)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wlogical-op)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wno-overlength-strings)
|
|
# AC_WIRESHARK_GCC_CFLAGS_CHECK(-fstrict-overflow -Wstrict-overflow=4)
|
|
# AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wunreachable-code)
|
|
# AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wunsafe-loop-optimizations)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wno-long-long)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wbad-function-cast, C)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wcast-qual)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Waddress)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Warray-bounds)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wattributes)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wdiv-by-zero)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wignored-qualifiers)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wpragmas)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wredundant-decls)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wvla)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wc++-compat, C)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wjump-misses-init, C)
|
|
#
|
|
# epan/dissectors/packet-ncp2222.inc blocks this one
|
|
# for now.
|
|
#
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wwrite-strings)
|
|
#
|
|
# GLib blocks this for now.
|
|
#
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wstrict-prototypes)
|
|
#
|
|
# All the registration functions block these for now.
|
|
#
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wmissing-prototypes)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wmissing-declarations)
|
|
#
|
|
# epan/dissectors/packet-afs.c blocks this one for now.
|
|
#
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wshadow)
|
|
#
|
|
# More cleanup needed for this on LP64.
|
|
#
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wshorten-64-to-32)
|
|
fi
|
|
],)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wall -W) # -W is now known as -Wextra
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wextra) # -W is now known as -Wextra
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wdeclaration-after-statement, C)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wendif-labels)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wpointer-arith)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wno-pointer-sign, C)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Warray-bounds)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wcast-align)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wformat-security)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wold-style-definition, C)
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-Wno-error=unused-but-set-variable) ## for now
|
|
#
|
|
# Use the faster pre gcc 4.5 floating point precision if available;
|
|
# clang doesn't error out on -f options that it doesn't know about,
|
|
# it just warns and ignores them, so this check doesn't cause us
|
|
# to omit -fexcess-precision=fast, which produces a pile of
|
|
# annoying warnings.
|
|
#
|
|
if test "x$CC" != "xclang" ; then
|
|
AC_WIRESHARK_GCC_CFLAGS_CHECK(-fexcess-precision=fast)
|
|
fi
|
|
|
|
AC_WIRESHARK_LDFLAGS_CHECK([-Wl,--as-needed])
|
|
###AC_WIRESHARK_LDFLAGS_CHECK([-Wl,-M])
|
|
###AC_WIRESHARK_LDFLAGS_CHECK([-Wl,--cref])
|
|
# AC_WIRESHARK_LDFLAGS_CHECK([-flto])
|
|
# AC_WIRESHARK_LDFLAGS_CHECK([-fwhopr])
|
|
# AC_WIRESHARK_LDFLAGS_CHECK([-fwhole-program])
|
|
|
|
#
|
|
# If we're running GCC or clang, add '-D_U_="__attribute__((unused))"' to
|
|
# CPPFLAGS as well, so we can use _U_ to flag unused function arguments and
|
|
# not get warnings about them. Otherwise, add '-D_U_=""', so that _U_ used
|
|
# to flag an unused function argument will compile with non-GCC, non-clang
|
|
# compilers.
|
|
#
|
|
# XXX - other compilers?
|
|
#
|
|
if test "x$GCC" = "xyes" -o "x$CC" = "xclang" ; then
|
|
CPPFLAGS="-D_U_=\"__attribute__((unused))\" $CPPFLAGS"
|
|
else
|
|
CPPFLAGS="-D_U_=\"\" $CPPFLAGS"
|
|
fi
|
|
|
|
# If we're running GCC or CLang, always use FORTIFY_SOURCE=2
|
|
# See: http://gcc.gnu.org/ml/gcc-patches/2004-09/msg02055.html
|
|
# Note: FORTIFY_SOURCE is only effective for gcc -O2 (and -O1 ?)
|
|
if test "x$GCC" = "xyes" -o "x$CC" = "xclang" ; then
|
|
CPPFLAGS="-D_FORTIFY_SOURCE=2 $CPPFLAGS"
|
|
fi
|
|
|
|
#
|
|
# If the compiler supports GCC-style flags, enable a barrier "stop on
|
|
# warning".
|
|
# This barrier is set for a very large part of the code. However, it is
|
|
# typically not set for "generated" code (flex, ans2wrs, idl2wrs, ...)
|
|
#
|
|
warnings_as_errors_default="yes"
|
|
AC_MSG_CHECKING(whether we should treat compiler warnings as errors)
|
|
AC_ARG_ENABLE(warnings-as-errors,
|
|
AC_HELP_STRING( [--enable-warnings-as-errors],
|
|
[treat warnings as errors (only for GCC or clang) @<:@default=yes@:>@]),
|
|
[
|
|
if test "x$ac_supports_gcc_flags" = "xyes" -a "x$enableval" = "xyes" -a "x$wireshark_extra_gcc_flags" != "xyes"; then
|
|
with_warnings_as_errors="yes"
|
|
AC_MSG_RESULT(yes)
|
|
else
|
|
with_warnings_as_errors="no"
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
],
|
|
if test "x$ac_supports_gcc_flags" = "xyes" -a "x$wireshark_extra_gcc_flags" = "x" -a "x$warnings_as_errors_default" = "xyes"; then
|
|
with_warnings_as_errors="yes"
|
|
AC_MSG_RESULT(yes)
|
|
else
|
|
with_warnings_as_errors="no"
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
)
|
|
AM_CONDITIONAL(HAVE_WARNINGS_AS_ERRORS, test "x$with_warnings_as_errors" = "xyes")
|
|
|
|
#
|
|
# Add any platform-specific compiler flags needed.
|
|
#
|
|
AC_MSG_CHECKING(for platform-specific compiler flags)
|
|
if test "x$GCC" = "xyes" ; then
|
|
#
|
|
# GCC - do any platform-specific tweaking necessary.
|
|
#
|
|
case "$host_os" in
|
|
solaris*)
|
|
# the X11 headers don't automatically include prototype info
|
|
# and a lot don't include the return type
|
|
CPPFLAGS="$CPPFLAGS -DFUNCPROTO=15"
|
|
CFLAGS="$CFLAGS -Wno-return-type"
|
|
CXXFLAGS="$CXXFLAGS -Wno-return-type"
|
|
AC_MSG_RESULT(GCC on Solaris - added -Wno-return-type -DFUNCPROTO=15)
|
|
;;
|
|
darwin*)
|
|
#
|
|
# See comments above about Apple's lovely C compiler.
|
|
#
|
|
# NOTE: to AC_PROG_CC, "GCC" means "any compiler that
|
|
# defines __GNUC__"; clang defines __GNUC__, so that
|
|
# means we think clang is GCC.
|
|
#
|
|
# clang whines about -no-cpp-precomp being unused
|
|
# so we check whether this is really clang, and
|
|
# only add -no-cpp-precomp if it's not.
|
|
#
|
|
if test "x$CC" != "xclang" ; then
|
|
CFLAGS="-no-cpp-precomp $CFLAGS"
|
|
AC_MSG_RESULT(Apple GCC - added -no-cpp-precomp)
|
|
else
|
|
#
|
|
# Clang, clang, clang went the trolley....
|
|
#
|
|
AC_MSG_RESULT(none needed)
|
|
fi
|
|
;;
|
|
*)
|
|
AC_MSG_RESULT(none needed)
|
|
;;
|
|
esac
|
|
else
|
|
#
|
|
# Not GCC - assume it's the vendor's compiler.
|
|
#
|
|
case "$host_os" in
|
|
hpux*)
|
|
#
|
|
# HP's ANSI C compiler; flags suggested by Jost Martin.
|
|
# "-Ae" for ANSI C plus extensions such as "long long".
|
|
# "+O2", for optimization. XXX - works with "-g"?
|
|
#
|
|
# HP's ANSI C++ compiler doesn't support "-Ae", but
|
|
# does support "+O2", at least according to the
|
|
# documentation I can find online.
|
|
#
|
|
CFLAGS="-Ae +O2 $CFLAGS"
|
|
CXXFLAGS="+O2 $CFLAGS"
|
|
AC_MSG_RESULT(HP ANSI C compiler - added -Ae +O2)
|
|
;;
|
|
darwin*)
|
|
#
|
|
# It may be called "cc", but it's really a GCC derivative
|
|
# with a problematic special precompiler and precompiled
|
|
# headers; turn off the special precompiler, as some
|
|
# apparently-legal code won't compile with its precompiled
|
|
# headers.
|
|
#
|
|
# On the other hand, if it's called "clang", it's not a
|
|
# GCC derivative, and it whines if you pass it
|
|
# -no-cpp-precomp.
|
|
#
|
|
# XXX - is there any version of autoconf we support
|
|
# where it uses another way to decide if the compiler
|
|
# is GCC or not?
|
|
#
|
|
if test "x$CC" != "xclang" ; then
|
|
CFLAGS="-no-cpp-precomp $CFLAGS"
|
|
AC_MSG_RESULT(Apple CC - added -no-cpp-precomp)
|
|
else
|
|
#
|
|
# Clang, clang, clang went the trolley....
|
|
#
|
|
AC_MSG_RESULT(none needed)
|
|
fi
|
|
;;
|
|
*)
|
|
AC_MSG_RESULT(none needed)
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
#
|
|
# Add any platform-specific linker flags needed.
|
|
#
|
|
AC_MSG_CHECKING(for platform-specific linker flags)
|
|
case "$host_os" in
|
|
darwin*)
|
|
#
|
|
# Add -Wl,-single_module to the LDFLAGS used with shared
|
|
# libraries, to fix some error that show up in some cases;
|
|
# some Apple documentation recommends it for most shared
|
|
# libraries.
|
|
#
|
|
LDFLAGS_SHAREDLIB="-Wl,-single_module"
|
|
#
|
|
# Add -Wl,-search_paths_first to make sure that if we search
|
|
# directories A and B, in that order, for a given library, a
|
|
# non-shared version in directory A, rather than a shared
|
|
# version in directory B, is chosen (so we can use
|
|
# --with-pcap=/usr/local to force all programs to be linked
|
|
# with a static version installed in /usr/local/lib rather than
|
|
# the system version in /usr/lib).
|
|
#
|
|
LDFLAGS="-Wl,-search_paths_first $LDFLAGS"
|
|
AC_MSG_RESULT([Apple linker - added -Wl,-single_module and -Wl,-search_paths_first])
|
|
;;
|
|
cygwin*)
|
|
#
|
|
# Shared libraries in cygwin/Win32 must never contain
|
|
# undefined symbols.
|
|
#
|
|
LDFLAGS="$LDFLAGS -no-undefined"
|
|
AC_MSG_RESULT(CygWin GNU ld - added -no-undefined)
|
|
;;
|
|
*)
|
|
AC_MSG_RESULT(none needed)
|
|
;;
|
|
esac
|
|
AC_SUBST(LDFLAGS_SHAREDLIB)
|
|
|
|
# Control silent compiling
|
|
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([no])])
|
|
|
|
#
|
|
# On OS X, if we find the headers for Core Foundation, Launch Services,
|
|
# and Core Services, add -framework options to link with Application
|
|
# Services (of which Launch Services is a subframework), Core Foundation
|
|
# (required by the Launch Services APIs), and Core Services, so we can
|
|
# use them to launch a Web browser from the Help menu and to use
|
|
# Gestalt() to get the Mac OS X version number.
|
|
#
|
|
case "$host_os" in
|
|
|
|
darwin*)
|
|
AC_MSG_CHECKING([whether we can build with Core Foundation, Launch Services, and Core Services])
|
|
ac_save_LIBS="$LIBS"
|
|
ac_coreservices_frameworks="-framework CoreServices"
|
|
ac_launchservices_frameworks="-framework ApplicationServices -framework CoreFoundation $ac_coreservices_frameworks"
|
|
LIBS="$LIBS $ac_launchservices_frameworks $ac_coreservices_frameworks"
|
|
AC_TRY_LINK(
|
|
[
|
|
# include <CoreFoundation/CFBase.h>
|
|
# include <CoreFoundation/CFString.h>
|
|
# include <CoreFoundation/CFURL.h>
|
|
# include <ApplicationServices/ApplicationServices.h>
|
|
# include <CoreServices/CoreServices.h>
|
|
],
|
|
[
|
|
CFStringRef url_CFString;
|
|
CFURLRef url_CFURL;
|
|
OSStatus status;
|
|
long os_version;
|
|
|
|
url_CFString = CFStringCreateWithCString(NULL, "", kCFStringEncodingASCII);
|
|
url_CFURL = CFURLCreateWithString(NULL, url_CFString, NULL);
|
|
status = LSOpenCFURLRef(url_CFURL, NULL);
|
|
|
|
Gestalt(gestaltSystemVersion, &os_version);
|
|
],
|
|
ac_cv_can_use_osx_frameworks=yes,
|
|
ac_cv_can_use_osx_frameworks=no,
|
|
[echo $ac_n "cross compiling; assumed OK... $ac_c"])
|
|
if test "$ac_cv_can_use_osx_frameworks" = yes ; then
|
|
AC_DEFINE(HAVE_OS_X_FRAMEWORKS, 1, [Define to 1 if you have OS X frameworks])
|
|
CORESERVICES_FRAMEWORKS="$ac_coreservices_frameworks"
|
|
LAUNCHSERVICES_FRAMEWORKS="$ac_launchservices_frameworks"
|
|
AC_MSG_RESULT(yes)
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
LIBS="$ac_save_LIBS"
|
|
;;
|
|
esac
|
|
AC_SUBST(CORESERVICES_FRAMEWORKS)
|
|
AC_SUBST(LAUNCHSERVICES_FRAMEWORKS)
|
|
|
|
#
|
|
# If using $prefix we add "$prefix/include" to the include search path
|
|
# and "$prefix/lib" to the library search path.
|
|
#
|
|
if test "x$prefix" != "x" ; then
|
|
AC_MSG_CHECKING(whether to use $prefix for headers and libraries)
|
|
if test -d $prefix/include ; then
|
|
AC_MSG_RESULT(yes)
|
|
#
|
|
# Arrange that we search for header files in "$prefix/include", as
|
|
# various packages we use may have been installed under "$prefix/include".
|
|
#
|
|
CPPFLAGS="$CPPFLAGS -I$prefix/include"
|
|
|
|
#
|
|
# Arrange that we search for libraries in "$prefix/lib".
|
|
#
|
|
AC_WIRESHARK_ADD_DASH_L(LDFLAGS, $prefix/lib)
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
fi
|
|
|
|
dnl Look in /usr/local for header files and libraries ?
|
|
dnl XXX FIXME don't include /usr/local if it is already in the system
|
|
dnl search path as this causes gcc 3.2 on Linux to complain about a change
|
|
dnl of the system search order for includes
|
|
AC_ARG_ENABLE(usr-local,
|
|
AC_HELP_STRING( [--enable-usr-local],
|
|
[look for headers and libs in /usr/local tree @<:@default=yes@:>@]),
|
|
ac_cv_enable_usr_local=$enableval,ac_cv_enable_usr_local=yes)
|
|
|
|
AC_MSG_CHECKING(whether to use /usr/local for headers and libraries)
|
|
if test "x$ac_cv_enable_usr_local" = "xyes" ; then
|
|
if test -d "/usr/local"; then
|
|
AC_MSG_RESULT(yes)
|
|
#
|
|
# Arrange that we search for header files in the source directory
|
|
# and in its "wiretap" subdirectory, as well as in "/usr/local/include",
|
|
# as various packages we use ("libpcap", "zlib", "adns")
|
|
# may have been installed under "/usr/local/include".
|
|
#
|
|
CPPFLAGS="$CPPFLAGS -I/usr/local/include"
|
|
|
|
#
|
|
# Arrange that we search for libraries in "/usr/local/lib".
|
|
#
|
|
AC_WIRESHARK_ADD_DASH_L(LDFLAGS, /usr/local/lib)
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
#
|
|
# If we're running Solaris, and LD_LIBRARY_PATH is defined, add it as a
|
|
# link directory.
|
|
#
|
|
case "$host_os" in
|
|
solaris*)
|
|
AC_MSG_CHECKING(for LD_LIBRARY_PATH, since you appear to be running Solaris)
|
|
if test x$LD_LIBRARY_PATH != x ; then
|
|
LIBS="$LIBS -R$LD_LIBRARY_PATH"
|
|
AC_MSG_RESULT(yes -- added LD_LIBRARY_PATH to run-time linker path)
|
|
else
|
|
AC_MSG_RESULT(no -- this may be a problem in a few seconds)
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
#
|
|
# Check for versions of "sed" inadequate to handle, in libtool, a list
|
|
# of object files as large as the list in Wireshark.
|
|
#
|
|
# On Solaris, we check for "/bin/sed", "/usr/bin/sed", and "/usr/ucb/sed",
|
|
# as both "/usr/bin/sed" (which is also "/bin/sed", as "/bin" is just a
|
|
# symlink to "/usr/bin", but people may have "/bin" before "/usr/bin" in
|
|
# their search path) and "/usr/ucb/sed" are inadequate; "/usr/xpg4/bin/sed"
|
|
# is the only "sed" that comes with Solaris that can handle Wireshark.
|
|
#
|
|
# Add any checks here that are necessary for other OSes.
|
|
#
|
|
AC_WIRESHARK_GNU_SED_CHECK
|
|
if test "$HAVE_GNU_SED" = no ; then
|
|
case "$host_os" in
|
|
solaris*)
|
|
AC_MSG_CHECKING(whether one of /usr/bin/sed or /bin/sed or /usr/ucb/sed will be used)
|
|
case `which sed` in
|
|
/bin/sed|/usr/bin/sed|/usr/ucb/sed)
|
|
AC_MSG_RESULT(yes)
|
|
AC_MSG_ERROR([change your path to search /usr/xpg4/bin or directory containing GNU sed before /usr/bin (and /bin and /usr/ucb)])
|
|
;;
|
|
|
|
*)
|
|
AC_MSG_RESULT(no)
|
|
;;
|
|
esac
|
|
;;
|
|
|
|
*)
|
|
:
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
# Enable/disable wireshark
|
|
|
|
AC_ARG_ENABLE(wireshark,
|
|
AC_HELP_STRING( [--enable-wireshark],
|
|
[build GTK+-based Wireshark @<:@default=yes, if GTK+ available@:>@]),
|
|
enable_wireshark=$enableval,enable_wireshark=yes)
|
|
|
|
AC_ARG_ENABLE(packet-editor,
|
|
AC_HELP_STRING( [--enable-packet-editor],
|
|
[add support for packet editor in Wireshark @<:@default=no@:>@]),
|
|
enable_packet_editor=$enableval,enable_packet_editor=no)
|
|
if test x$enable_packet_editor = xyes; then
|
|
AC_DEFINE(WANT_PACKET_EDITOR, 1, [Support for packet editor])
|
|
fi
|
|
|
|
AC_ARG_ENABLE(profile-build,
|
|
AC_HELP_STRING( [--enable-profile-build],
|
|
[build profile-ready binaries @<:@default=no@:>@]),
|
|
enable_profile_build=$enableval,enable_profile_build=no)
|
|
AM_CONDITIONAL(USE_PROFILE_BUILD, test x$enable_profile_build = xyes)
|
|
AC_MSG_CHECKING(if profile builds must be generated)
|
|
if test "x$enable_profile_build" = "xyes" ; then
|
|
if test "x$GCC" = "xyes" -o "x$CLANG" = "xyes" ; then
|
|
AC_MSG_RESULT(yes)
|
|
CFLAGS=" -pg $CFLAGS"
|
|
CXXFLAGS=" -pg $CXXFLAGS"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
echo "Building profile binaries currently only supported for GCC and clang."
|
|
fi
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
# Create DATAFILE_DIR #define for config.h
|
|
datafiledir=$datadir/wireshark
|
|
datafiledir=`(
|
|
test "x$prefix" = xNONE && prefix=$ac_default_prefix
|
|
test "x$exec_prefix" = xNONE && exec_prefix=${prefix}
|
|
# Ugly hack, but I don't see how this problem can be solved
|
|
# properly that DATAFILE_DIR had a value starting with
|
|
# "${prefix}/" instead of e.g. "/usr/local/"
|
|
eval eval echo "$datafiledir"
|
|
)`
|
|
AC_DEFINE_UNQUOTED(DATAFILE_DIR,"$datafiledir", [Directory for data])
|
|
|
|
# Create DOC_DIR #define for config.h
|
|
docdir=`(
|
|
test "x$prefix" = xNONE && prefix=$ac_default_prefix
|
|
test "x$exec_prefix" = xNONE && exec_prefix=${prefix}
|
|
# Ugly hack, but I don't see how this problem can be solved
|
|
# properly that DOC_DIR had a value starting with
|
|
# "${prefix}/" instead of e.g. "/usr/local/"
|
|
eval eval echo "$docdir"
|
|
)`
|
|
AC_DEFINE_UNQUOTED(DOC_DIR, "$docdir", [Directory for docs])
|
|
|
|
# GTK+ and Qt checks; we require GTK+ 2.12 or later, and, for now,
|
|
# don't require any particular version of Qt (except perhaps by
|
|
# implication, as older versions might not support pkgconfig).
|
|
#
|
|
# We only do those if we're going to be building Wireshark;
|
|
# otherwise, we don't have any GUI to build, so we don't use
|
|
# GTK+ or Qt.
|
|
#
|
|
# We don't add $GTK_LIBS or $Qt_LIBS to LIBS, because we don't want to
|
|
# force all programs to be built with GTK+ or Qt.
|
|
#
|
|
if test "x$enable_wireshark" = "xyes"; then
|
|
if test "x$with_qt" = "xyes"; then
|
|
PKG_CHECK_MODULES([Qt], [QtCore QtGui],
|
|
[
|
|
CFLAGS="$CFLAGS $Qt_CFLAGS"
|
|
CXXFLAGS="$CXXFLAGS $Qt_CFLAGS"
|
|
#
|
|
# XXX - greasy hack to make ui/gtk/recent.c
|
|
# compile.
|
|
#
|
|
CPPFLAGS="-DQT_GUI_LIB $CPPFLAGS"
|
|
have_qt=yes
|
|
],
|
|
[
|
|
AC_MSG_ERROR([Qt is not available])
|
|
])
|
|
|
|
#
|
|
# We don't know whether we have GTK+, but we
|
|
# won't be using it, so it's as if we don't
|
|
# have it.
|
|
#
|
|
have_gtk=no
|
|
else
|
|
#
|
|
# Not Qt - either GTK+ 3.x or 2.x.
|
|
#
|
|
if test "x$with_gtk3" = "xyes"; then
|
|
AM_PATH_GTK_3_0(3.0.0,
|
|
[
|
|
CFLAGS="$CFLAGS $GTK_CFLAGS"
|
|
CXXFLAGS="$CXXFLAGS $GTK_CFLAGS"
|
|
have_gtk=yes
|
|
AC_DEFINE(HAVE_GTK, 1,
|
|
[Define to 1 if compiling with GTK])
|
|
], have_gtk=no)
|
|
|
|
else
|
|
AM_PATH_GTK_2_0(2.12.0,
|
|
[
|
|
CFLAGS="$CFLAGS $GTK_CFLAGS"
|
|
CXXFLAGS="$CXXFLAGS $GTK_CFLAGS"
|
|
have_gtk=yes
|
|
AC_DEFINE(HAVE_GTK, 1,
|
|
[Define to 1 if compiling with GTK])
|
|
], have_gtk=no)
|
|
fi
|
|
fi
|
|
else
|
|
have_qt=no
|
|
have_gtk=no
|
|
fi
|
|
|
|
# GLib checks; we require GLib 2.14 or later, and require gmodule
|
|
# support, as we need that for dynamically loading plugins.
|
|
# If we found GTK+, this doesn't add GLIB_CFLAGS to CFLAGS, because
|
|
# AM_PATH_GTK will add GTK_CFLAGS to CFLAGS, and GTK_CFLAGS is a
|
|
# superset of GLIB_CFLAGS. If we didn't find GTK+, it does add
|
|
# GLIB_CFLAGS to CFLAGS.
|
|
# However, this means that both @GLIB_LIBS@ and @GTK_LIBS@ will be
|
|
# set when generating the Makefile, so we can make programs that require
|
|
# only GLib link with @GLIB_LIBS@ and make programs that require GTK+
|
|
# link with @GTK_LIBS@ (which includes @GLIB_LIBS@).
|
|
# We don't add $GLIB_LIBS to LIBS, because we don't want to force all
|
|
# programs to be built with GLib.
|
|
#
|
|
if test "$have_gtk" = "no" ; then
|
|
#
|
|
# We don't have GTK+.
|
|
#
|
|
if test "$have_qt" = "yes" ; then
|
|
#
|
|
# However, we do have Qt, and thus will be building
|
|
# Wireshark (if the user had explicitly disabled
|
|
# Wireshark, we wouldn't have looked for Qt, so we
|
|
# wouldn't think we had it, and thus wouldn't be here).
|
|
#
|
|
wireshark_bin="wireshark\$(EXEEXT)"
|
|
wireshark_man="wireshark.1"
|
|
wireshark_SUBDIRS="codecs ui/qt"
|
|
else
|
|
#
|
|
# We don't have Qt, either, which means we have no UI
|
|
# toolkit.
|
|
#
|
|
# If they didn't explicitly say "--disable-wireshark",
|
|
# fail (so that, unless they explicitly indicated that
|
|
# they don't want Wireshark, we stop so they know they
|
|
# won't be getting Wireshark unless they fix the GTK+/Qt
|
|
# problem).
|
|
#
|
|
if test "x$enable_wireshark" = "xyes"; then
|
|
if test "x$with_gtk3" = "xyes"; then
|
|
AC_MSG_ERROR([GTK+ 3.0 or later isn't available, so Wireshark can't be compiled])
|
|
else
|
|
AC_MSG_ERROR([Neither Qt nor GTK+ 2.12 or later are available, so Wireshark can't be compiled])
|
|
fi
|
|
fi
|
|
wireshark_bin=""
|
|
wireshark_man=""
|
|
fi
|
|
# Use GLIB_CFLAGS
|
|
AM_PATH_GLIB_2_0(2.14.0,
|
|
[
|
|
CFLAGS="$CFLAGS $GLIB_CFLAGS"
|
|
CXXFLAGS="$CXXFLAGS $GLIB_CFLAGS"
|
|
], AC_MSG_ERROR(GLib 2.14 or later distribution not found.), gthread gmodule)
|
|
else
|
|
#
|
|
# We have GTK+, and thus will be building Wireshark (if the user
|
|
# had explicitly disabled Wireshark, we wouldn't have looked for
|
|
# GTK+, so we wouldn't think we had it, and thus wouldn't be here).
|
|
#
|
|
wireshark_bin="wireshark\$(EXEEXT)"
|
|
wireshark_man="wireshark.1"
|
|
wireshark_SUBDIRS="codecs ui/gtk"
|
|
# Don't use GLIB_CFLAGS
|
|
AM_PATH_GLIB_2_0(2.14.0, , AC_MSG_ERROR(GLib 2.14 or later distribution not found.), gthread gmodule)
|
|
|
|
CPPFLAGS="-DGTK_DISABLE_SINGLE_INCLUDES $CPPFLAGS"
|
|
## Define GTK_DISABLE_DEPRECATED only if GTK lt 3.2
|
|
## GTK 3.2 deprecates GtkVBox & GtkHBox which are currently used extensively by Wireshark.
|
|
if test $gtk_config_major_version -eq 2 -o $gtk_config_minor_version -lt 2; then
|
|
CPPFLAGS="-DGTK_DISABLE_DEPRECATED $CPPFLAGS"
|
|
fi
|
|
# CPPFLAGS="-DGDK_DISABLE_DEPRECATED $CPPFLAGS"
|
|
if test $gtk_config_major_version -eq 2 -a $gtk_config_minor_version -ge 20; then
|
|
# Enable GSEAL when building with GTK > 2.20 and < 3.0
|
|
# (Versions prior to 2.22 lacked some necessary accessors.)
|
|
CPPFLAGS="-DGSEAL_ENABLE $CPPFLAGS"
|
|
fi
|
|
fi
|
|
|
|
# Error out if a glib header other than a "top level" header
|
|
# (glib.h, glib-object.h, gio.h) or certain other headers( e.g.,gmodule.h)
|
|
# is used.
|
|
CPPFLAGS="-DG_DISABLE_SINGLE_INCLUDES $CPPFLAGS"
|
|
|
|
# Error out on the usage of deprecated glib functions
|
|
CPPFLAGS="-DG_DISABLE_DEPRECATED $CPPFLAGS"
|
|
|
|
#
|
|
# Check whether GLib modules are supported, to determine whether we
|
|
# can support plugins.
|
|
#
|
|
AC_MSG_CHECKING(whether GLib supports loadable modules)
|
|
ac_save_CFLAGS="$CFLAGS"
|
|
ac_save_LIBS="$LIBS"
|
|
CFLAGS="$CFLAGS $GLIB_CFLAGS"
|
|
LIBS="$GLIB_LIBS $LIBS"
|
|
AC_TRY_RUN([
|
|
#include <glib.h>
|
|
#include <gmodule.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
int
|
|
main ()
|
|
{
|
|
if (g_module_supported())
|
|
return 0; /* success */
|
|
else
|
|
return 1; /* failure */
|
|
}
|
|
], ac_cv_glib_supports_modules=yes, ac_cv_glib_supports_modules=no,
|
|
[echo $ac_n "cross compiling; assumed OK... $ac_c"
|
|
ac_cv_glib_supports_modules=yes])
|
|
CFLAGS="$ac_save_CFLAGS"
|
|
LIBS="$ac_save_LIBS"
|
|
if test "$ac_cv_glib_supports_modules" = yes ; then
|
|
AC_MSG_RESULT(yes)
|
|
have_plugins=yes
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
have_plugins=no
|
|
fi
|
|
|
|
#
|
|
# If we have <dlfcn.h>, check whether we can use dladdr to find a
|
|
# filename (hopefully, a full pathname, but no guarantees) for
|
|
# the executable.
|
|
#
|
|
if test "$ac_cv_header_dlfcn_h" = "yes"
|
|
then
|
|
AC_MSG_CHECKING(whether dladdr can be used to find the pathname of an executable)
|
|
ac_save_CFLAGS="$CFLAGS"
|
|
ac_save_LIBS="$LIBS"
|
|
CFLAGS="$CFLAGS $GLIB_CFLAGS"
|
|
LIBS="$GLIB_LIBS $LIBS"
|
|
AC_TRY_RUN([
|
|
#define _GNU_SOURCE /* required on Linux, sigh */
|
|
#include <dlfcn.h>
|
|
|
|
int
|
|
main(void)
|
|
{
|
|
Dl_info info;
|
|
|
|
if (!dladdr((void *)main, &info))
|
|
return 1; /* failure */
|
|
return 0; /* assume success */
|
|
}
|
|
], ac_cv_dladdr_finds_executable_path=yes, ac_cv_dladdr_finds_executable_path=no,
|
|
[echo $ac_n "cross compiling; assumed OK... $ac_c"
|
|
ac_cv_dladdr_finds_executable_path=yes])
|
|
CFLAGS="$ac_save_CFLAGS"
|
|
LIBS="$ac_save_LIBS"
|
|
if test x$ac_cv_dladdr_finds_executable_path = xyes
|
|
then
|
|
AC_DEFINE(DLADDR_FINDS_EXECUTABLE_PATH, 1, [Define if dladdr can be used to find the path of the executable])
|
|
fi
|
|
AC_MSG_RESULT($ac_cv_dladdr_finds_executable_path)
|
|
fi
|
|
|
|
if test "x$have_gtk" = "xyes"
|
|
then
|
|
#
|
|
# We have GTK+; do we want the OS X integration functions and,
|
|
# if so, do we have them and, if so, which versions do we have,
|
|
# the old Carbon-based ones or the new Cocoa-based ones?
|
|
#
|
|
AC_MSG_CHECKING(whether to use OS X integration functions)
|
|
|
|
AC_ARG_WITH(osx-integration,
|
|
AC_HELP_STRING( [--with-osx-integration],
|
|
[use OS X integration functions @<:@default=yes, if available@:>@]),
|
|
[
|
|
if test $withval = no
|
|
then
|
|
want_osx_integration=no
|
|
else
|
|
want_osx_integration=yes
|
|
fi
|
|
],[
|
|
want_osx_integration=yes
|
|
])
|
|
if test "x$want_osx_integration" = "xno"; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_OSX_INTEGRATION_CHECK
|
|
fi
|
|
fi
|
|
|
|
AC_SUBST(wireshark_bin)
|
|
AC_SUBST(wireshark_man)
|
|
|
|
|
|
# Enable/disable tshark
|
|
|
|
AC_ARG_ENABLE(tshark,
|
|
AC_HELP_STRING( [--enable-tshark],
|
|
[build TShark @<:@default=yes@:>@]),
|
|
tshark=$enableval,enable_tshark=yes)
|
|
|
|
if test "x$enable_tshark" = "xyes" ; then
|
|
tshark_bin="tshark\$(EXEEXT)"
|
|
tshark_man="tshark.1"
|
|
wiresharkfilter_man="wireshark-filter.4"
|
|
else
|
|
tshark_bin=""
|
|
tshark_man=""
|
|
fi
|
|
AC_SUBST(tshark_bin)
|
|
AC_SUBST(tshark_man)
|
|
AC_SUBST(wiresharkfilter_man)
|
|
|
|
|
|
|
|
# Enable/disable editcap
|
|
|
|
AC_ARG_ENABLE(editcap,
|
|
AC_HELP_STRING( [--enable-editcap],
|
|
[build editcap @<:@default=yes@:>@]),
|
|
enable_editcap=$enableval,enable_editcap=yes)
|
|
|
|
if test "x$enable_editcap" = "xyes" ; then
|
|
editcap_bin="editcap\$(EXEEXT)"
|
|
editcap_man="editcap.1"
|
|
else
|
|
editcap_bin=""
|
|
editcap_man=""
|
|
fi
|
|
AC_SUBST(editcap_bin)
|
|
AC_SUBST(editcap_man)
|
|
|
|
# Enabling/disabling of dumpcap is done later (after we know if we have PCAP
|
|
# or not)
|
|
|
|
# Enable/disable capinfos
|
|
|
|
AC_ARG_ENABLE(capinfos,
|
|
AC_HELP_STRING( [--enable-capinfos],
|
|
[build capinfos @<:@default=yes@:>@]),
|
|
enable_capinfos=$enableval,enable_capinfos=yes)
|
|
|
|
if test "x$enable_capinfos" = "xyes" ; then
|
|
capinfos_bin="capinfos\$(EXEEXT)"
|
|
capinfos_man="capinfos.1"
|
|
else
|
|
capinfos_bin=""
|
|
capinfos_man=""
|
|
fi
|
|
AC_SUBST(capinfos_bin)
|
|
AC_SUBST(capinfos_man)
|
|
|
|
|
|
# Enable/disable mergecap
|
|
|
|
AC_ARG_ENABLE(mergecap,
|
|
AC_HELP_STRING( [--enable-mergecap],
|
|
[build mergecap @<:@default=yes@:>@]),
|
|
enable_mergecap=$enableval,enable_mergecap=yes)
|
|
|
|
if test "x$enable_mergecap" = "xyes" ; then
|
|
mergecap_bin="mergecap\$(EXEEXT)"
|
|
mergecap_man="mergecap.1"
|
|
else
|
|
mergecap_bin=""
|
|
mergecap_man=""
|
|
fi
|
|
AC_SUBST(mergecap_bin)
|
|
AC_SUBST(mergecap_man)
|
|
|
|
|
|
# Enable/disable text2pcap
|
|
|
|
AC_ARG_ENABLE(text2pcap,
|
|
AC_HELP_STRING( [--enable-text2pcap],
|
|
[build text2pcap @<:@default=yes@:>@]),
|
|
text2pcap=$enableval,enable_text2pcap=yes)
|
|
|
|
if test "x$enable_text2pcap" = "xyes" ; then
|
|
text2pcap_bin="text2pcap\$(EXEEXT)"
|
|
text2pcap_man="text2pcap.1"
|
|
else
|
|
text2pcap_bin=""
|
|
text2pcap_man=""
|
|
fi
|
|
AC_SUBST(text2pcap_bin)
|
|
AC_SUBST(text2pcap_man)
|
|
|
|
|
|
# Enable/disable dftest
|
|
|
|
AC_ARG_ENABLE(dftest,
|
|
AC_HELP_STRING( [--enable-dftest],
|
|
[build dftest @<:@default=yes@:>@]),
|
|
enable_dftest=$enableval,enable_dftest=yes)
|
|
|
|
if test "x$enable_dftest" = "xyes" ; then
|
|
dftest_bin="dftest\$(EXEEXT)"
|
|
dftest_man="dftest.1"
|
|
else
|
|
dftest_bin=""
|
|
dftest_man=""
|
|
fi
|
|
AC_SUBST(dftest_bin)
|
|
AC_SUBST(dftest_man)
|
|
|
|
|
|
# Enable/disable randpkt
|
|
|
|
AC_ARG_ENABLE(randpkt,
|
|
AC_HELP_STRING( [--enable-randpkt],
|
|
[build randpkt @<:@default=yes@:>@]),
|
|
enable_randpkt=$enableval,enable_randpkt=yes)
|
|
|
|
if test "x$enable_randpkt" = "xyes" ; then
|
|
randpkt_bin="randpkt\$(EXEEXT)"
|
|
randpkt_man="randpkt.1"
|
|
else
|
|
randpkt_bin=""
|
|
randpkt_man=""
|
|
fi
|
|
AC_SUBST(randpkt_bin)
|
|
AC_SUBST(randpkt_man)
|
|
|
|
|
|
|
|
dnl Checks for "gethostbyname()" - and "-lnsl", if we need it to get
|
|
dnl "gethostbyname()".
|
|
AC_WIRESHARK_GETHOSTBY_LIB_CHECK
|
|
|
|
dnl Checks for "connect()", used as a proxy for "socket()" - and
|
|
dnl "-lsocket", if we need it to get "connect()".
|
|
AC_WIRESHARK_SOCKET_LIB_CHECK
|
|
|
|
dnl pcap check
|
|
AC_MSG_CHECKING(whether to use libpcap for packet capture)
|
|
|
|
AC_ARG_WITH(pcap,
|
|
AC_HELP_STRING( [--with-pcap@<:@=DIR@:>@],
|
|
[use libpcap for packet capturing @<:@default=yes@:>@]),
|
|
[
|
|
if test $withval = no
|
|
then
|
|
want_pcap=no
|
|
elif test $withval = yes
|
|
then
|
|
want_pcap=yes
|
|
else
|
|
want_pcap=yes
|
|
pcap_dir=$withval
|
|
fi
|
|
],[
|
|
want_pcap=yes
|
|
pcap_dir=
|
|
])
|
|
if test "x$want_pcap" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_PCAP_CHECK
|
|
fi
|
|
|
|
|
|
dnl Check for airpcap
|
|
AC_MSG_CHECKING(whether to include airpcap support)
|
|
AC_ARG_ENABLE(airpcap,
|
|
AC_HELP_STRING( [--enable-airpcap],
|
|
[use AirPcap in Wireshark @<:@default=yes@:>@]),
|
|
enable_airpcap=$enableval, enable_airpcap=yes)
|
|
|
|
if test x$enable_airpcap = xyes; then
|
|
if test "x$want_pcap" = "xno" ; then
|
|
enable_airpcap=no
|
|
AC_MSG_RESULT(pcap not available - disabling airpcap)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_AIRPCAP, 1, [Enable AirPcap])
|
|
fi
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
|
|
dnl dumpcap check
|
|
AC_MSG_CHECKING(whether to build dumpcap)
|
|
|
|
AC_ARG_ENABLE(dumpcap,
|
|
AC_HELP_STRING( [--enable-dumpcap],
|
|
[build dumpcap @<:@default=yes@:>@]),
|
|
enable_dumpcap=$enableval,enable_dumpcap=yes)
|
|
|
|
if test "x$enable_dumpcap" = "xyes" ; then
|
|
if test "x$want_pcap" = "xno" ; then
|
|
enable_dumpcap=no
|
|
AC_MSG_RESULT(pcap not available - disabling dumpcap)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
fi
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
if test "x$enable_dumpcap" = "xyes" ; then
|
|
dumpcap_bin="dumpcap\$(EXEEXT)"
|
|
dumpcap_man="dumpcap.1"
|
|
else
|
|
dumpcap_bin=""
|
|
dumpcap_man=""
|
|
fi
|
|
AC_SUBST(dumpcap_bin)
|
|
AC_SUBST(dumpcap_man)
|
|
|
|
# Enable/disable rawshark
|
|
|
|
dnl rawshark check
|
|
AC_MSG_CHECKING(whether to build rawshark)
|
|
|
|
AC_ARG_ENABLE(rawshark,
|
|
AC_HELP_STRING( [--enable-rawshark],
|
|
[build rawshark @<:@default=yes@:>@]),
|
|
rawshark=$enableval,enable_rawshark=yes)
|
|
|
|
if test "x$enable_rawshark" = "xyes" ; then
|
|
if test "x$want_pcap" = "xno" ; then
|
|
enable_rawshark=no
|
|
AC_MSG_RESULT(pcap not available - disabling rawshark)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
fi
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
if test "x$enable_rawshark" = "xyes" ; then
|
|
rawshark_bin="rawshark\$(EXEEXT)"
|
|
rawshark_man="rawshark.1"
|
|
else
|
|
rawshark_bin=""
|
|
rawshark_man=""
|
|
fi
|
|
AC_SUBST(rawshark_bin)
|
|
AC_SUBST(rawshark_man)
|
|
|
|
dnl Use pcap-ng by default
|
|
AC_ARG_ENABLE(pcap-ng-default,
|
|
AC_HELP_STRING( [--enable-pcap-ng-default],
|
|
[use the pcap-ng file format by default instead of pcap @<:@default=yes@:>@]),
|
|
enable_pcap_ng_default=$enableval,enable_pcap_ng_default=yes)
|
|
if test x$enable_pcap_ng_default = xyes; then
|
|
AC_DEFINE(PCAP_NG_DEFAULT, 1, [Support for pcap-ng])
|
|
fi
|
|
|
|
dnl pcap remote check
|
|
AC_MSG_CHECKING(whether to use libpcap remote capturing feature)
|
|
|
|
AC_ARG_WITH(pcap-remote,
|
|
AC_HELP_STRING([--with-pcap-remote],
|
|
[use libpcap remote capturing (requires libpcap)]),
|
|
[
|
|
if test $withval = no
|
|
then
|
|
want_pcap_remote=no
|
|
else
|
|
want_pcap_remote=yes
|
|
fi
|
|
],[
|
|
want_pcap_remote=no
|
|
])
|
|
if test "x$want_pcap_remote" = "xno" -o "x$want_pcap" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_PCAP_REMOTE_CHECK
|
|
fi
|
|
|
|
dnl zlib check
|
|
AC_MSG_CHECKING(whether to use zlib for gzip compression and decompression)
|
|
|
|
AC_ARG_WITH(zlib,
|
|
AC_HELP_STRING([--with-zlib@<:@=DIR@:>@],
|
|
[use zlib (located in directory DIR, if supplied) for gzip compression and decompression @<:@default=yes, if available@:>@]),
|
|
[
|
|
if test "x$withval" = "xno"
|
|
then
|
|
want_zlib=no
|
|
elif test "x$withval" = "xyes"
|
|
then
|
|
want_zlib=yes
|
|
else
|
|
want_zlib=yes
|
|
zlib_dir="$withval"
|
|
fi
|
|
],[
|
|
#
|
|
# Use zlib if it's present, otherwise don't.
|
|
#
|
|
want_zlib=ifavailable
|
|
zlib_dir=
|
|
])
|
|
if test "x$want_zlib" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_ZLIB_CHECK
|
|
if test "x$want_zlib" = "xno" ; then
|
|
AC_MSG_RESULT(zlib not found - disabling gzip compression and decompression)
|
|
else
|
|
if test "x$ac_cv_func_inflatePrime" = "xno" ; then
|
|
AC_MSG_RESULT(inflatePrime not found in zlib - disabling gzipped capture file support)
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
dnl Lua check
|
|
AC_MSG_CHECKING(whether to use liblua for the Lua scripting plugin)
|
|
|
|
AC_ARG_WITH(lua,
|
|
AC_HELP_STRING( [--with-lua@<:@=DIR@:>@],
|
|
[use liblua (located in directory DIR, if supplied) for the Lua scripting plugin @<:@default=yes, if available@:>@]),
|
|
[
|
|
if test $withval = no
|
|
then
|
|
want_lua=no
|
|
elif test $withval = yes
|
|
then
|
|
want_lua=yes
|
|
else
|
|
want_lua=yes
|
|
lua_dir=$withval
|
|
fi
|
|
],[
|
|
#
|
|
# Use liblua by default
|
|
#
|
|
want_lua=ifavailable
|
|
lua_dir=
|
|
])
|
|
if test "x$want_lua" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_LIBLUA_CHECK
|
|
if test "x$want_lua" = "xno" ; then
|
|
AC_MSG_RESULT(liblua not found - disabling support for the lua scripting plugin)
|
|
fi
|
|
fi
|
|
AM_CONDITIONAL(HAVE_LIBLUA, test x$want_lua = xyes)
|
|
|
|
|
|
dnl portaudio check
|
|
AC_MSG_CHECKING(whether to use libportaudio for the rtp_player)
|
|
|
|
AC_ARG_WITH(portaudio,
|
|
AC_HELP_STRING( [--with-portaudio@<:@=DIR@:>@],
|
|
[use libportaudio (located in directory DIR, if supplied) for the rtp_player @<:@default=yes, if available@:>@]),
|
|
[
|
|
if test $withval = no
|
|
then
|
|
want_portaudio=no
|
|
elif test $withval = yes
|
|
then
|
|
want_portaudio=yes
|
|
else
|
|
want_portaudio=yes
|
|
portaudio_dir=$withval
|
|
fi
|
|
],[
|
|
#
|
|
# Use libportaudio by default
|
|
#
|
|
want_portaudio=ifavailable
|
|
portaudio_dir=
|
|
])
|
|
if test "x$want_portaudio" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_LIBPORTAUDIO_CHECK
|
|
if test "x$want_portaudio" = "xno" ; then
|
|
AC_MSG_RESULT(libportaudio not found - disabling support for the rtp_player)
|
|
fi
|
|
fi
|
|
AM_CONDITIONAL(HAVE_LIBPORTAUDIO, test x$want_portaudio = xyes)
|
|
|
|
|
|
dnl ipv6 check
|
|
AC_ARG_ENABLE(ipv6,
|
|
AC_HELP_STRING( [--enable-ipv6],
|
|
[use IPv6 name resolution, if available @<:@default=yes@:>@]),
|
|
enable_ipv6=$enableval,enable_ipv6=yes)
|
|
|
|
AC_MSG_CHECKING(whether to enable ipv6 name resolution if available)
|
|
if test "x$enable_ipv6" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_IPV6_STACK
|
|
fi
|
|
|
|
|
|
dnl Check if dumpcap should be installed with filesystem capabilities
|
|
AC_PATH_PROG(SETCAP, setcap)
|
|
AC_ARG_ENABLE(setcap-install,
|
|
AC_HELP_STRING( [--enable-setcap-install],
|
|
[install dumpcap with cap_net_admin and cap_net_raw @<:@default=no@:>@]),
|
|
enable_setcap_install=$enableval,enable_setcap_install=no)
|
|
|
|
AC_MSG_CHECKING(whether to install dumpcap with cap_net_admin and cap_net_raw capabilities)
|
|
if test "x$enable_setcap_install" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
if test "x$SETCAP" = "x" ; then
|
|
AC_MSG_RESULT(no. Setcap not found)
|
|
elif test "x$enable_dumpcap" = "xno" ; then
|
|
AC_MSG_ERROR(Setcap install works only with dumpcap but dumpcap is disabled)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
fi
|
|
fi
|
|
|
|
AM_CONDITIONAL(SETCAP_INSTALL, test x$enable_setcap_install = xyes)
|
|
|
|
dnl Check if dumpcap should be installed setuid
|
|
AC_ARG_ENABLE(setuid-install,
|
|
AC_HELP_STRING( [--enable-setuid-install],
|
|
[install dumpcap as setuid @<:@default=no@:>@]),
|
|
enable_setuid_install=$enableval,enable_setuid_install=no)
|
|
|
|
AC_MSG_CHECKING(whether to install dumpcap setuid)
|
|
if test "x$enable_setuid_install" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
if test "x$enable_setcap_install" = "xyes" ; then
|
|
enable_setuid_install=no
|
|
AC_MSG_RESULT(no; using setcap instead)
|
|
elif test "x$enable_dumpcap" = "xno" ; then
|
|
AC_MSG_ERROR(Setuid install works only with dumpcap but dumpcap is disabled)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
fi
|
|
fi
|
|
|
|
AM_CONDITIONAL(SETUID_INSTALL, test x$enable_setuid_install = xyes)
|
|
AC_CHECK_FUNCS(setresuid setresgid)
|
|
|
|
dnl ...but our Network Operations group is named "no"!
|
|
DUMPCAP_GROUP=''
|
|
AC_ARG_WITH(dumpcap-group,
|
|
AC_HELP_STRING( [--with-dumpcap-group=GROUP],
|
|
[restrict dumpcap to GROUP]),
|
|
[
|
|
if test "x$withval" = "xyes"; then
|
|
AC_MSG_ERROR([No dumpcap group specified.])
|
|
elif test "x$withval" != "xno"; then
|
|
if test "x$enable_dumpcap" = "xno" ; then
|
|
AC_MSG_ERROR(dumpcap group install works only with dumpcap but dumpcap is disabled)
|
|
fi
|
|
AC_MSG_RESULT($withval)
|
|
DUMPCAP_GROUP="$withval"
|
|
fi
|
|
])
|
|
AC_SUBST(DUMPCAP_GROUP)
|
|
AM_CONDITIONAL(HAVE_DUMPCAP_GROUP, test x$DUMPCAP_GROUP != x)
|
|
|
|
dnl libcap (not libpcap) check
|
|
LIBCAP_LIBS=''
|
|
AC_MSG_CHECKING(whether to use the libcap capabilities library)
|
|
|
|
AC_ARG_WITH(libcap,
|
|
AC_HELP_STRING( [--with-libcap@<:@=DIR@:>@],
|
|
[use libcap (located in directory DIR, if supplied) for POSIX.1e capabilities management @<:@default=yes, if present@:>@]),
|
|
[
|
|
if test "x$withval" = "xno"; then
|
|
want_libcap=no
|
|
elif test "x$withval" = "xyes"; then
|
|
want_libcap=yes
|
|
elif test -d "$withval"; then
|
|
want_libcap=yes
|
|
AC_WIRESHARK_ADD_DASH_L(LDFLAGS, ${withval}/lib)
|
|
fi
|
|
])
|
|
if test "x$with_libcap" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_LIBCAP_CHECK
|
|
fi
|
|
AC_SUBST(LIBCAP_LIBS)
|
|
|
|
dnl Checks for header files.
|
|
AC_CHECK_HEADERS(direct.h dirent.h fcntl.h grp.h inttypes.h netdb.h pwd.h stdarg.h stddef.h unistd.h)
|
|
AC_CHECK_HEADERS(sys/ioctl.h sys/param.h sys/socket.h sys/sockio.h sys/stat.h sys/time.h sys/types.h sys/utsname.h sys/wait.h)
|
|
AC_CHECK_HEADERS(netinet/in.h)
|
|
AC_CHECK_HEADERS(arpa/inet.h arpa/nameser.h)
|
|
|
|
dnl SSL Check
|
|
SSL_LIBS=''
|
|
AC_MSG_CHECKING(whether to use SSL library)
|
|
|
|
AC_ARG_WITH(ssl,
|
|
AC_HELP_STRING( [--with-ssl@<:@=DIR@:>@],
|
|
[use SSL crypto library (located in directory DIR, if supplied) @<:@default=no@:>@]),
|
|
[
|
|
if test "x$withval" = "xno"; then
|
|
want_ssl=no
|
|
elif test "x$withval" = "xyes"; then
|
|
want_ssl=yes
|
|
elif test -d "$withval"; then
|
|
want_ssl=yes
|
|
AC_WIRESHARK_ADD_DASH_L(LDFLAGS, ${withval}/lib)
|
|
fi
|
|
],[
|
|
want_ssl=no
|
|
])
|
|
if test "x$want_ssl" = "xyes"; then
|
|
AC_MSG_RESULT(yes)
|
|
AC_CHECK_LIB(crypto,EVP_md5,
|
|
[
|
|
SSL_LIBS=-lcrypto
|
|
],
|
|
[
|
|
AC_MSG_ERROR([SSL crypto library was requested, but is not available])
|
|
])
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
AC_SUBST(SSL_LIBS)
|
|
|
|
dnl kerberos check
|
|
AC_MSG_CHECKING(whether to use Kerberos library)
|
|
|
|
AC_ARG_WITH(krb5,
|
|
AC_HELP_STRING( [--with-krb5@<:@=DIR@:>@],
|
|
[use Kerberos library (located in directory DIR, if supplied) to use in Kerberos dissection @<:@default=yes@:>@]),
|
|
[
|
|
if test $withval = no
|
|
then
|
|
want_krb5=no
|
|
elif test $withval = yes
|
|
then
|
|
want_krb5=yes
|
|
else
|
|
want_krb5=yes
|
|
krb5_dir=$withval
|
|
fi
|
|
],[
|
|
#
|
|
# Use Kerberos library if available, otherwise don't.
|
|
#
|
|
want_krb5=ifavailable
|
|
krb5_dir=
|
|
])
|
|
if test "x$want_krb5" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_KRB5_CHECK
|
|
fi
|
|
|
|
|
|
dnl c-ares Check
|
|
C_ARES_LIBS=''
|
|
AC_MSG_CHECKING(whether to use the c-ares library if available)
|
|
|
|
AC_ARG_WITH(c-ares,
|
|
AC_HELP_STRING( [--with-c-ares@<:@=DIR@:>@],
|
|
[use c-ares (located in directory DIR, if supplied) - supersedes --with-adns @<:@default=yes, if present@:>@]),
|
|
[
|
|
if test "x$withval" = "xno"; then
|
|
want_c_ares=no
|
|
elif test "x$withval" = "xyes"; then
|
|
want_c_ares=yes
|
|
elif test -d "$withval"; then
|
|
want_c_ares=yes
|
|
AC_WIRESHARK_ADD_DASH_L(LDFLAGS, ${withval}/lib)
|
|
fi
|
|
])
|
|
if test "x$want_c_ares" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_C_ARES_CHECK
|
|
fi
|
|
AC_SUBST(C_ARES_LIBS)
|
|
|
|
dnl ADNS Check
|
|
ADNS_LIBS=''
|
|
AC_MSG_CHECKING(whether to use the GNU ADNS library if available)
|
|
|
|
AC_ARG_WITH(adns,
|
|
AC_HELP_STRING( [--with-adns@<:@=DIR@:>@],
|
|
[use GNU ADNS (located in directory DIR, if supplied) @<:@default=yes, if present@:>@]),
|
|
[
|
|
if test "x$withval" = "xno"; then
|
|
want_adns=no
|
|
elif test "x$withval" = "xyes"; then
|
|
want_adns=yes
|
|
elif test -d "$withval"; then
|
|
want_adns=yes
|
|
AC_WIRESHARK_ADD_DASH_L(LDFLAGS, ${withval}/lib)
|
|
fi
|
|
])
|
|
if test "x$want_adns" = "xno" -o "x$have_good_c_ares" = "xyes" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_ADNS_CHECK
|
|
fi
|
|
AC_SUBST(ADNS_LIBS)
|
|
|
|
dnl GEOIP Check
|
|
GEOIP_LIBS=''
|
|
AC_MSG_CHECKING(whether to use the GeoIP IP address mapping library if available)
|
|
|
|
AC_ARG_WITH(geoip,
|
|
AC_HELP_STRING( [--with-geoip@<:@=DIR@:>@],
|
|
[use GeoIP (located in directory DIR, if supplied) @<:@default=yes, if present@:>@]),
|
|
[
|
|
if test "x$withval" = "xno"; then
|
|
want_geoip=no
|
|
elif test "x$withval" = "xyes"; then
|
|
want_geoip=yes
|
|
elif test -d "$withval"; then
|
|
want_geoip=yes
|
|
AC_WIRESHARK_ADD_DASH_L(LDFLAGS, ${withval}/lib)
|
|
fi
|
|
])
|
|
if test "x$want_geoip" = "xno"; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_GEOIP_CHECK
|
|
fi
|
|
AC_SUBST(GEOIP_LIBS)
|
|
|
|
dnl Python devel Check
|
|
AC_MSG_CHECKING(whether to use the Python interpreter for scripting)
|
|
|
|
AC_ARG_WITH(python,
|
|
AC_HELP_STRING( [--with-python@<:@=DIR@:>@],
|
|
[use Python interpreter (installed in DIR, if supplied) @<:@default=no@:>@ (BROKEN/UNSTABLE)]),
|
|
[
|
|
pythondir='${libdir}/wireshark/python/${VERSION}'
|
|
if test "x$withval" = "xno"
|
|
then
|
|
want_python=no
|
|
elif test "x$withval" = "xyes"
|
|
then
|
|
want_python=yes
|
|
else
|
|
want_python=yes
|
|
pythondir="$withval"
|
|
fi
|
|
],[
|
|
# By default (user didn't explicitly enable Python), don't enable
|
|
# Python support.
|
|
#
|
|
want_python=no
|
|
#pythondir='${libdir}/wireshark/python/${VERSION}'
|
|
])
|
|
if test "x$want_python" = "xno" ; then
|
|
AC_MSG_RESULT(no)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_WIRESHARK_PYTHON_CHECK
|
|
fi
|
|
AM_CONDITIONAL(HAVE_LIBPY, test x$want_python != xno)
|
|
AC_SUBST(pythondir)
|
|
|
|
#
|
|
# Define WS_VAR_IMPORT appropriately for declarations of external
|
|
# variables exported from dynamically-linked libraries.
|
|
#
|
|
AC_DEFINE(WS_VAR_IMPORT, extern, [Define as the string to precede external variable declarations in dynamically-linked libraries])
|
|
|
|
#
|
|
# Define WS_MSVC_NORETURN appropriately for declarations of routines that
|
|
# never return (just like Charlie on the MTA).
|
|
#
|
|
# Note that MSVC++ expects __declspec(noreturn) to precede the function
|
|
# name and GCC, as far as I know, expects __attribute__((noreturn)) to
|
|
# follow the function name, so we need two different flavors of
|
|
# noreturn tag.
|
|
#
|
|
AC_DEFINE(WS_MSVC_NORETURN,, [Define as the string to precede declarations of routines that never return])
|
|
|
|
dnl Checks for typedefs, structures, and compiler characteristics.
|
|
# AC_C_CONST
|
|
|
|
# Check how we can get the time zone abbreviation
|
|
AC_WIRESHARK_TIMEZONE_ABBREV
|
|
|
|
# We need to know whether "struct sockaddr" has an "sa_len" member
|
|
# for get_interface_list().
|
|
|
|
AC_WIRESHARK_STRUCT_SA_LEN
|
|
|
|
# We must know our byte order
|
|
AC_C_BIGENDIAN
|
|
|
|
# Checks whether "-traditional" is needed when using "ioctl".
|
|
# XXX - do we need this?
|
|
AC_PROG_GCC_TRADITIONAL
|
|
|
|
GETOPT_LO=""
|
|
AC_CHECK_FUNC(getopt,
|
|
[GETOPT_LO=""
|
|
AC_DEFINE(HAVE_GETOPT, 1, [Define to 1 if you have the getopt function.])
|
|
],
|
|
GETOPT_LO="wsgetopt.lo"
|
|
)
|
|
if test "$ac_cv_func_getopt" = no ; then
|
|
GETOPT_LO="wsgetopt.lo"
|
|
fi
|
|
AM_CONDITIONAL(NEED_GETOPT_LO, test "x$ac_cv_func_getopt" = "xno")
|
|
AC_SUBST(GETOPT_LO)
|
|
|
|
AC_CHECK_FUNC(strncasecmp, STRNCASECMP_LO="",
|
|
STRNCASECMP_LO="strncasecmp.lo")
|
|
if test "$ac_cv_func_strncasecmp" = no ; then
|
|
STRNCASECMP_LO="strncasecmp.lo"
|
|
fi
|
|
AM_CONDITIONAL(NEED_STRNCASECMP_LO, test "x$ac_cv_func_strncasecmp" = "xno")
|
|
AC_SUBST(STRNCASECMP_LO)
|
|
|
|
AC_CHECK_FUNCS(mkstemp mkdtemp)
|
|
|
|
AC_SEARCH_LIBS(inet_aton, [socket nsl], have_inet_aton=yes,
|
|
have_inet_aton=no)
|
|
if test "$have_inet_aton" = no; then
|
|
INET_ATON_LO="inet_aton.lo"
|
|
AC_DEFINE(NEED_INET_ATON_H, 1, [Define if inet/aton.h needs to be included])
|
|
else
|
|
INET_ATON_LO=""
|
|
fi
|
|
AM_CONDITIONAL(NEED_INET_ATON_LO, test "x$have_inet_aton" = "xno")
|
|
AC_SUBST(INET_ATON_LO)
|
|
|
|
AC_SEARCH_LIBS(inet_pton, [socket nsl], [
|
|
dnl check for pre-BIND82 inet_pton() bug.
|
|
AC_MSG_CHECKING(for broken inet_pton)
|
|
AC_TRY_RUN([#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <arpa/inet.h>
|
|
int main()
|
|
{
|
|
#ifdef AF_INET6
|
|
char buf[16];
|
|
/* this should return 0 (error) */
|
|
return inet_pton(AF_INET6, "0:1:2:3:4:5:6:7:", buf);
|
|
#else
|
|
return 1;
|
|
#endif
|
|
}], [AC_MSG_RESULT(ok);
|
|
have_inet_pton=yes], [AC_MSG_RESULT(broken);
|
|
have_inet_pton=no], [AC_MSG_RESULT(cross compiling, assume it is broken);
|
|
have_inet_pton=no])],
|
|
have_inet_pton=no)
|
|
if test "$have_inet_pton" = no; then
|
|
INET_PTON_LO="inet_pton.lo"
|
|
else
|
|
INET_PTON_LO=""
|
|
fi
|
|
AM_CONDITIONAL(NEED_INET_PTON_LO, test "x$have_inet_pton" = "xno")
|
|
AC_SUBST(INET_PTON_LO)
|
|
|
|
AC_SEARCH_LIBS(inet_ntop, [socket nsl], [
|
|
AC_MSG_CHECKING([for inet_ntop prototype])
|
|
AC_TRY_COMPILE([#include <stdio.h>
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <arpa/inet.h>
|
|
|
|
extern const char *inet_ntop(int, const void *, char *, size_t);],, [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_INET_NTOP_PROTO, 1,
|
|
[Define if inet_ntop() prototype exists])], [
|
|
AC_TRY_COMPILE([#include <stdio.h>
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <arpa/inet.h>
|
|
|
|
extern const char *inet_ntop(int, const void *, char *, socklen_t);],, [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_INET_NTOP_PROTO, 1,
|
|
[Define if inet_ntop() prototype exists])], [
|
|
AC_MSG_RESULT(no)])])
|
|
INET_NTOP_LO=""], [
|
|
INET_NTOP_LO="inet_ntop.lo"
|
|
AC_DEFINE(NEED_INET_V6DEFS_H, 1,
|
|
[Define if inet/v6defs.h needs to be included])])
|
|
AM_CONDITIONAL(NEED_INET_NTOP_LO, test "x$INET_NTOP_LO" != "x")
|
|
AC_SUBST(INET_NTOP_LO)
|
|
|
|
AC_CHECK_FUNC(strptime, STRPTIME_LO="",
|
|
[STRPTIME_LO="strptime.lo"
|
|
AC_DEFINE(NEED_STRPTIME_H, 1, [Define if strptime.h needs to be included])
|
|
])
|
|
if test "$ac_cv_func_strptime" = no ; then
|
|
STRPTIME_LO="strptime.lo"
|
|
fi
|
|
AC_SUBST(STRPTIME_C)
|
|
AM_CONDITIONAL(NEED_STRPTIME_LO, test "x$ac_cv_func_strptime" = "no")
|
|
AC_SUBST(STRPTIME_LO)
|
|
|
|
AC_CHECK_FUNCS(getprotobynumber gethostbyname2)
|
|
AC_CHECK_FUNCS(issetugid)
|
|
AC_CHECK_FUNCS(mmap mprotect sysconf)
|
|
AC_CHECK_FUNCS(strtoll)
|
|
|
|
dnl blank for now, but will be used in future
|
|
AC_SUBST(wireshark_SUBDIRS)
|
|
|
|
dnl
|
|
dnl check whether plugins should be enabled and, if they should be,
|
|
dnl check for plugins directory - stolen from Amanda's configure.in
|
|
dnl
|
|
dnl we don't wish to expand ${libdir} yet
|
|
plugindir='${libdir}/wireshark/plugins/${VERSION}'
|
|
AC_ARG_WITH(plugins,
|
|
AC_HELP_STRING( [--with-plugins@<:@=DIR@:>@],
|
|
[support plugins (installed in DIR, if supplied) @<:@default=yes, if possible@:>@]),
|
|
[
|
|
if test "x$withval" = "xno"; then
|
|
have_plugins=no
|
|
elif test "x$have_plugins" = "xno"; then
|
|
AC_MSG_ERROR([GLib on this platform doesn't support loadable modules, so you can't enable plugins.])
|
|
elif test "x$withval" != "xyes"; then
|
|
plugindir="$withval"
|
|
fi
|
|
])
|
|
AM_CONDITIONAL(HAVE_PLUGINS, test "x$have_plugins" = "xyes")
|
|
if test x$have_plugins = xyes
|
|
then
|
|
AC_DEFINE(HAVE_PLUGINS, 1, [Define if plugins are enabled])
|
|
fi
|
|
AC_SUBST(plugindir)
|
|
CPPFLAGS="$CPPFLAGS '-DPLUGIN_DIR=\"\$(plugindir)\"'"
|
|
|
|
#
|
|
# The plugin dissectors reside in ./plugins/PROTO/
|
|
#
|
|
PLUGIN_LIBS=""
|
|
AC_SUBST(PLUGIN_LIBS)
|
|
|
|
#
|
|
# Check if (emem) memory allocations must be 8-byte aligned.
|
|
# I haven't been able to write C code that reliably makes that determination
|
|
# (different versions of GCC with or without optimization give different
|
|
# results) so just assume everything except (32-bit) x86 needs 8-byte
|
|
# alignment (64-bit x86 will get 8-byte alignment from G_MEM_ALIGN anyway).
|
|
#
|
|
AC_MSG_CHECKING(whether we need memory allocations to be 8-byte aligned)
|
|
if test x$host_cpu != xi386
|
|
then
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(NEED_8_BYTE_ALIGNMENT, 1, [Define if we need memory allocations to be 8-byte aligned])
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
dnl libtool defs
|
|
#
|
|
# Yes, AM_PROG_LIBTOOL is redundant with newer version(s) of some tool(s)
|
|
# (autoconf? automake? libtool?) - with the newer version(s), it's
|
|
# just an alias for AC_PROG_LIBTOOL, which is called earlier.
|
|
#
|
|
# With older version(s) of those tool(s), however, it's not just an
|
|
# alias, and the configure scripts don't work without it.
|
|
#
|
|
AM_PROG_LIBTOOL
|
|
AC_SUBST(LIBTOOL_DEPS)
|
|
|
|
AM_CONDITIONAL(ENABLE_STATIC, test x$enable_static = xyes)
|
|
if test x$enable_static = xyes -a x$have_plugins = xyes
|
|
then
|
|
AC_DEFINE(ENABLE_STATIC, 1, [Link plugins statically into Wireshark])
|
|
fi
|
|
AC_SUBST(ENABLE_STATIC)
|
|
|
|
dnl Save the cacheable configure results to config.cache before recursing
|
|
AC_CACHE_SAVE
|
|
|
|
sinclude(plugins/Custom.m4) dnl
|
|
ifdef(_CUSTOM_AC_OUTPUT_,, define(_CUSTOM_AC_OUTPUT_, )) dnl
|
|
|
|
sinclude(asn1/Custom.m4) dnl
|
|
ifdef(_CUSTOM_ASN1_AC_OUTPUT_,, define(_CUSTOM_ASN1_AC_OUTPUT_, )) dnl
|
|
|
|
AM_CONFIG_HEADER(config.h)
|
|
AC_OUTPUT(
|
|
Makefile
|
|
doxygen.cfg
|
|
asn1/Makefile
|
|
_CUSTOM_ASN1_AC_OUTPUT_
|
|
asn1/acp133/Makefile
|
|
asn1/acse/Makefile
|
|
asn1/ansi_map/Makefile
|
|
asn1/ansi_tcap/Makefile
|
|
asn1/c1222/Makefile
|
|
asn1/camel/Makefile
|
|
asn1/cdt/Makefile
|
|
asn1/charging_ase/Makefile
|
|
asn1/cmip/Makefile
|
|
asn1/cmp/Makefile
|
|
asn1/crmf/Makefile
|
|
asn1/cms/Makefile
|
|
asn1/credssp/Makefile
|
|
asn1/dap/Makefile
|
|
asn1/disp/Makefile
|
|
asn1/dop/Makefile
|
|
asn1/dsp/Makefile
|
|
asn1/ess/Makefile
|
|
asn1/ftam/Makefile
|
|
asn1/gnm/Makefile
|
|
asn1/goose/Makefile
|
|
asn1/gprscdr/Makefile
|
|
asn1/gsm_map/Makefile
|
|
asn1/h225/Makefile
|
|
asn1/h235/Makefile
|
|
asn1/h245/Makefile
|
|
asn1/h248/Makefile
|
|
asn1/h282/Makefile
|
|
asn1/h283/Makefile
|
|
asn1/h323/Makefile
|
|
asn1/h450/Makefile
|
|
asn1/h450-ros/Makefile
|
|
asn1/h460/Makefile
|
|
asn1/h501/Makefile
|
|
asn1/HI2Operations/Makefile
|
|
asn1/hnbap/Makefile
|
|
asn1/idmp/Makefile
|
|
asn1/inap/Makefile
|
|
asn1/kerberos/Makefile
|
|
asn1/lcsap/Makefile
|
|
asn1/ldap/Makefile
|
|
asn1/logotypecertextn/Makefile
|
|
asn1/lpp/Makefile
|
|
asn1/lppa/Makefile
|
|
asn1/lte-rrc/Makefile
|
|
asn1/m3ap/Makefile
|
|
asn1/mms/Makefile
|
|
asn1/mpeg-audio/Makefile
|
|
asn1/mpeg-pes/Makefile
|
|
asn1/nbap/Makefile
|
|
asn1/ns_cert_exts/Makefile
|
|
asn1/ocsp/Makefile
|
|
asn1/p1/Makefile
|
|
asn1/p22/Makefile
|
|
asn1/p7/Makefile
|
|
asn1/p772/Makefile
|
|
asn1/pcap/Makefile
|
|
asn1/pkcs1/Makefile
|
|
asn1/pkcs12/Makefile
|
|
asn1/pkinit/Makefile
|
|
asn1/pkixac/Makefile
|
|
asn1/pkix1explicit/Makefile
|
|
asn1/pkix1implicit/Makefile
|
|
asn1/pkixproxy/Makefile
|
|
asn1/pkixqualified/Makefile
|
|
asn1/pkixtsp/Makefile
|
|
asn1/pres/Makefile
|
|
asn1/q932/Makefile
|
|
asn1/q932-ros/Makefile
|
|
asn1/qsig/Makefile
|
|
asn1/ranap/Makefile
|
|
asn1/rnsap/Makefile
|
|
asn1/ros/Makefile
|
|
asn1/rrc/Makefile
|
|
asn1/rrlp/Makefile
|
|
asn1/rtse/Makefile
|
|
asn1/rua/Makefile
|
|
asn1/s1ap/Makefile
|
|
asn1/sabp/Makefile
|
|
asn1/sbc-ap/Makefile
|
|
asn1/smrse/Makefile
|
|
asn1/snmp/Makefile
|
|
asn1/spnego/Makefile
|
|
asn1/sv/Makefile
|
|
asn1/t124/Makefile
|
|
asn1/t125/Makefile
|
|
asn1/t38/Makefile
|
|
asn1/tcap/Makefile
|
|
asn1/tetra/Makefile
|
|
asn1/ulp/Makefile
|
|
asn1/wlancertextn/Makefile
|
|
asn1/x2ap/Makefile
|
|
asn1/x509af/Makefile
|
|
asn1/x509ce/Makefile
|
|
asn1/x509if/Makefile
|
|
asn1/x509sat/Makefile
|
|
asn1/x721/Makefile
|
|
doc/Makefile
|
|
docbook/Makefile
|
|
epan/Makefile
|
|
epan/crypt/Makefile
|
|
epan/doxygen.cfg
|
|
epan/dfilter/Makefile
|
|
epan/dissectors/Makefile
|
|
epan/dissectors/dcerpc/Makefile
|
|
epan/dissectors/pidl/Makefile
|
|
epan/ftypes/Makefile
|
|
epan/wslua/Makefile
|
|
epan/wspython/Makefile
|
|
codecs/Makefile
|
|
ui/Makefile
|
|
ui/doxygen.cfg
|
|
ui/gtk/Makefile
|
|
ui/gtk/doxygen.cfg
|
|
ui/cli/Makefile
|
|
ui/qt/Makefile
|
|
ui/qt/doxygen.cfg
|
|
help/Makefile
|
|
packaging/Makefile
|
|
packaging/macosx/Info.plist
|
|
packaging/macosx/Makefile
|
|
packaging/nsis/Makefile
|
|
packaging/rpm/Makefile
|
|
packaging/rpm/SPECS/Makefile
|
|
packaging/rpm/SPECS/wireshark.spec
|
|
packaging/svr4/Makefile
|
|
packaging/svr4/checkinstall
|
|
packaging/svr4/pkginfo
|
|
plugins/Makefile
|
|
plugins/asn1/Makefile
|
|
plugins/docsis/Makefile
|
|
plugins/ethercat/Makefile
|
|
plugins/giop/Makefile
|
|
plugins/gryphon/Makefile
|
|
plugins/irda/Makefile
|
|
plugins/m2m/Makefile
|
|
plugins/mate/Makefile
|
|
plugins/opcua/Makefile
|
|
plugins/profinet/Makefile
|
|
plugins/stats_tree/Makefile
|
|
plugins/unistim/Makefile
|
|
plugins/wimax/Makefile
|
|
plugins/wimaxasncp/Makefile
|
|
tools/Makefile
|
|
tools/lemon/Makefile
|
|
wiretap/Makefile
|
|
wsutil/Makefile
|
|
_CUSTOM_AC_OUTPUT_
|
|
,)
|
|
dnl AC_CONFIG_FILES([tools/setuid-root.pl], [chmod +x tools/setuid-root.pl])
|
|
|
|
|
|
# Pretty messages
|
|
|
|
if test "x$have_qt" = "xyes"; then
|
|
gui_lib_message=" (with Qt)"
|
|
else
|
|
if test "x$have_gtk" = "xyes"; then
|
|
if test "x$with_gtk3" = "xyes"; then
|
|
gui_lib_message=" (with GTK+ 3"
|
|
else
|
|
gui_lib_message=" (with GTK+ 2"
|
|
fi
|
|
if test "x$have_ige_mac" = "xyes"; then
|
|
gui_lib_message="$gui_lib_message and Mac OS X integration)"
|
|
else
|
|
gui_lib_message="$gui_lib_message)"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test "x$enable_setcap_install" = "xyes" ; then
|
|
setcap_message="yes"
|
|
else
|
|
setcap_message="no"
|
|
fi
|
|
|
|
if test "x$enable_setuid_install" = "xyes" ; then
|
|
setuid_message="yes"
|
|
else
|
|
setuid_message="no"
|
|
fi
|
|
|
|
if test "x$DUMPCAP_GROUP" = "x" ; then
|
|
dumpcap_group_message="(none)"
|
|
else
|
|
dumpcap_group_message="$DUMPCAP_GROUP"
|
|
fi
|
|
|
|
if test "x$want_zlib" = "xno" ; then
|
|
zlib_message="no"
|
|
else
|
|
zlib_message="yes"
|
|
fi
|
|
|
|
if test "x$want_lua" = "xyes" ; then
|
|
lua_message="yes"
|
|
else
|
|
lua_message="no"
|
|
fi
|
|
|
|
if test "x$want_python" = "xno"; then
|
|
python_message="no"
|
|
else
|
|
python_message="yes"
|
|
fi
|
|
|
|
if test "x$want_portaudio" = "xyes" ; then
|
|
portaudio_message="yes"
|
|
else
|
|
portaudio_message="no"
|
|
fi
|
|
|
|
if test "x$want_ssl" = "xno" ; then
|
|
ssl_message="no"
|
|
else
|
|
ssl_message="yes"
|
|
fi
|
|
|
|
if test "x$want_krb5" = "xno" ; then
|
|
krb5_message="no"
|
|
else
|
|
krb5_message="yes ($ac_krb5_version)"
|
|
fi
|
|
|
|
if test "x$have_good_c_ares" = "xyes" ; then
|
|
c_ares_message="yes"
|
|
else
|
|
c_ares_message="no"
|
|
fi
|
|
|
|
if test "x$have_good_adns" = "xyes" ; then
|
|
adns_message="yes"
|
|
else
|
|
if test "x$have_good_c_ares" = "xyes" ; then
|
|
adns_message="no (using c-ares instead)"
|
|
else
|
|
adns_message="no"
|
|
fi
|
|
fi
|
|
|
|
if test "x$have_good_libcap" = "xyes" ; then
|
|
libcap_message="yes"
|
|
else
|
|
libcap_message="no"
|
|
fi
|
|
|
|
if test "x$have_good_geoip" = "xyes" ; then
|
|
geoip_message="yes"
|
|
else
|
|
geoip_message="no"
|
|
fi
|
|
|
|
echo ""
|
|
echo "The Wireshark package has been configured with the following options."
|
|
echo " Build wireshark : $enable_wireshark""$gui_lib_message"
|
|
echo " Build tshark : $enable_tshark"
|
|
echo " Build capinfos : $enable_capinfos"
|
|
echo " Build editcap : $enable_editcap"
|
|
echo " Build dumpcap : $enable_dumpcap"
|
|
echo " Build mergecap : $enable_mergecap"
|
|
echo " Build text2pcap : $enable_text2pcap"
|
|
echo " Build randpkt : $enable_randpkt"
|
|
echo " Build dftest : $enable_dftest"
|
|
echo " Build rawshark : $enable_rawshark"
|
|
echo ""
|
|
echo " Save files as pcap-ng by default : $enable_pcap_ng_default"
|
|
echo " Install dumpcap with capabilities : $setcap_message"
|
|
echo " Install dumpcap setuid : $setuid_message"
|
|
echo " Use dumpcap group : $dumpcap_group_message"
|
|
echo " Use plugins : $have_plugins"
|
|
echo " Use Lua library : $lua_message"
|
|
echo " Use Python binding : $python_message"
|
|
echo " Build rtp_player : $portaudio_message"
|
|
echo " Build profile binaries : $enable_profile_build"
|
|
echo " Use pcap library : $want_pcap"
|
|
echo " Use zlib library : $zlib_message"
|
|
echo " Use kerberos library : $krb5_message"
|
|
echo " Use c-ares library : $c_ares_message"
|
|
echo " Use GNU ADNS library : $adns_message"
|
|
echo " Use SMI MIB library : $libsmi_message"
|
|
echo " Use GNU crypto library : $gcrypt_message"
|
|
echo " Use SSL crypto library : $ssl_message"
|
|
echo " Use IPv6 name resolution : $enable_ipv6"
|
|
echo " Use gnutls library : $tls_message"
|
|
echo " Use POSIX capabilities library : $libcap_message"
|
|
echo " Use GeoIP library : $geoip_message"
|