# ===========================================================================
# https://www.gnu.org/software/autoconf-archive/ax_path_milter.html
# ===========================================================================
#
# SYNOPSIS
#
# AX_PATH_MILTER([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]])
#
# DESCRIPTION
#
# This macro tries to automatically find the library libmilter.a and the
# header file "libmilter/mfapi.h", which are required when compiling a
# milter for Sendmail. When successful, it sets the output variable
# MILTER_LIBS to "-lmilter", MILTER_LDFLAGS to contain an -Lpathtolib
# option, and MILTER_CPPFLAGS to contain an -Ipathtoinclude option, if
# they are necessary.
#
# The easiest way to use this macro is something like:
#
# AX_PATH_MILTER([8.12],[
# LIBS="$MILTER_LIBS $LIBS"
# LDFLAGS="$MILTER_LDFLAGS $LDFLAGS"
# CPPFLAGS="$CPPFLAGS $MILTER_CPPFLAGS"
# ],[
# AC_MSG_ERROR([required milter library and header not found])
# ])
#
# If the macro is successful, it just adds any flags to the necessary
# environment. If it is not successful, it would likely be a fatal error,
# because if an application is linking with libmilter.a, it is probably
# because it is a milter.
#
# There are two optional "--with" options for configure which are added.
# If they are specified, they override any searching that is done. They
# are:
#
# --with-sendmail-base=
This option is used to explicitly
# specify the base of the sendmail distribution.
#
# --with-sendmail-obj= The option is used to explicitly specify
# the "obj.*" subdirectory in the sendmail distribution
# that should be used.
#
# When sendmail-base is not specified, the current environment is first
# tested to see if the header and library are available, and if so
# MILTER_LDFLAGS and MILTER_CPPFLAGS are left empty.
#
# There are two places that are searched for the sendmail base directory.
# The first location is one directory down from the current directory. It
# checks if there is a directory of the form sendmail-8.1*, limited to
# version 8.12.x or higher, then chooses the directory with the highest
# version number. If that method does not succeed, it then looks in the
# file /etc/mail/sendmail.cf for the directory it was built from, and uses
# the base of that distribution. If neither of these methods work, then it
# fails.
#
# There are two methods for finding the "obj.*" directory when it is not
# specified. The first is to try to run sendmail's Build program with the
# -M option which will print out the name of the obj. directory for the
# tool in the directory where it is run from. If this does not work, is
# looks for the newest directory of the form "obj.*" in the sendmail base
# directory.
#
# Two addition output variables that are defined, whether or not the files
# are found are SENDMAIL_BASE_DIR and SENDMAIL_OBJ_DIR, which are the
# suspected location of the sendmail base directory and obj.*
# subdirectory.
#
# NOTE: POSIX threads MUST be configured BEFORE this function is called or
# it will not find libmilter.a even if it exists. The easiest way is to
# use the AX_PTHREAD macro by Steven G. Johnson and Alejandro Forero
# Cuervo which is available from the Autoconf Macro Archive.
#
# LICENSE
#
# Copyright (c) 2008 Tim Toolan
#
# Copying and distribution of this file, with or without modification, are
# permitted in any medium without royalty provided the copyright notice
# and this notice are preserved. This file is offered as-is, without any
# warranty.
#serial 12
###############################################################################
AC_DEFUN([AX_PATH_MILTER], [
# Used to indicate success or failure of this function.
ax_path_milter_ok=no
# Convert sections of MINIMUM-VERSION to three digit numbers by adding zeros.
# For example 8.12.9 would become 008.012.009
ac_milter_minimum_version=`echo "$1" | sed 's,\([[0-9]]*\),x\1x,g;s,x\([[0-9]]\)x,x0\1x,g;s,x\([[0-9]][[0-9]]\)x,x0\1x,g;s,x,,g'`
# Add options --with-sendmail-base and --with-sendmail-obj to configure.
AC_ARG_WITH([sendmail-base],
[ --with-sendmail-base= base directory of sendmail distribution])
AC_ARG_WITH([sendmail-obj],
[ --with-sendmail-obj= obj.* subdirectory in sendmail distribution])
# Check for functions required by libmilter.
AC_CHECK_FUNC(inet_aton, [], [AC_SEARCH_LIBS(inet_aton, [socket nsl resolv])])
AC_CHECK_FUNC(socket, [], [AC_SEARCH_LIBS(socket, [socket nsl])])
AC_CHECK_FUNC(gethostbyname, [], [AC_SEARCH_LIBS(gethostbyname, [socket nsl])])
###############################################################################
#
# If neither --with-sendmail-base or --with-sendmail-obj is specified
# check the existing environment first for mfapi.h and libmilter without
# modifying CPPFLAGS, LDFLAGS, and LIBS first.
#
if test "x$with_sendmail_base$with_sendmail_obj" = "x" ; then
AC_CHECK_HEADER([libmilter/mfapi.h],[
AC_CHECK_LIB([milter],[smfi_main],[
# both tests succeeded so indicate success
ax_path_milter_ok=yes
# add -lmilter to the libraries to link
MILTER_LIBS="-lmilter"
])
])
if test "$ax_path_milter_ok" = "no" ; then
# Unset the cached test results because we will be trying them again later.
ac_milter_tmp=abcdefg
if unset ac_milter_tmp 2> /dev/null ; then
unset ac_cv_header_libmilter_mfapi_h
unset ac_cv_lib_milter_smfi_main
else
AC_MSG_WARN(
[system doesn't have unset so either use --with-sendmail-base
or set LDFLAGS and CPPFLAGS with the necessary -L and -I options])
fi
fi
fi
###############################################################################
#
# If didn't already fine necessary files then search.
#
if test "$ax_path_milter_ok" = "no" ; then
#############################################################################
#
# Determine the sendmail base directory and set SENDMAIL_BASE_DIR.
#
if test "x$with_sendmail_base" != "x" ; then
# set SENDMAIL_BASE_DIR to the one specified by--with-sendmail-base
SENDMAIL_BASE_DIR="$with_sendmail_base"
else
AC_MSG_CHECKING([for sendmail base directory in ../ ])
#
# --with-sendmail-base is not used, so we will try to determine it
#
# 1) List all directories one level down that look like sendmail.
# 2) Select ones that are sendmail 8.12 or higher (including 8.13
# versions when they come out).
# 3) Replace any single digit last version numbers with a two digit
# version number (ie. 8.12.9 becomes 8.12.09).
# 4) Sort all of the directories found in reverse order.
# 5) Take the first one (the highest version).
# 6) Restore the single digit version numbers.
#
ac_milter_tmp=`ls -d ../sendmail-8.1* 2> /dev/null | grep '../sendmail-8.1[[2-9]]' | sed 's,\.\([[0-9]]\)$,.0\1,' | sort -r | sed '1q' | sed 's,\.0\([[0-9]]\)$,.\1,'`
# Convert found version sections to three digit numbers by adding zeros.
ac_milter_found_version=`echo "$ac_milter_tmp" | sed 's,.*/sendmail-,,;s,\([[0-9]]*\),x\1x,g;s,x\([[0-9]]\)x,x0\1x,g;s,x\([[0-9]][[0-9]]\)x,x0\1x,g;s,x,,g'`
# If ac_milter_minimum_version is equal to ac_milter_lower_version, then
# the found version is greater than or equal to the minimum version.
# Pick the version string that is the lesser of the two.
# An empty string would be less than anything.
# In short, ac_milter_version_ok will equal yes if the version is ok,
# and no otherwise.
ac_milter_version_ok=`echo "x$ac_milter_minimum_version
x$ac_milter_found_version" | sort | sed '1q' | sed "s,x${ac_milter_minimum_version},yes,;s,x${ac_milter_found_version},no," `
# If we have something add the current directory to it.
if test "x$ac_milter_tmp" != "x" ; then
ac_milter_tmp="`pwd`/$ac_milter_tmp"
fi
if test -r "${ac_milter_tmp}/include/libmilter/mfapi.h" && \
test "$ac_milter_version_ok" = "yes" ; then
# The file mfapi.h exists so we will use this as SENDMAIL_BASE_DIR.
AC_MSG_RESULT([yes])
SENDMAIL_BASE_DIR="$ac_milter_tmp"
else
AC_MSG_RESULT([no])
AC_MSG_CHECKING([for sendmail base from /etc/mail/sendmail.cf])
#
# The previous method to find SENDMAIL_BASE_DIR failed, so we will
# try this method.
#
# 1) Check for a line in /etc/mail/sendmail.cf of the form:
# ##### in /some/path/sendmail-8.x.x/more/path
# This is the directory that the sendmail.cf file was built in.
# 2) Take the first occurrence if there are more than one.
# 3) Remove the leading "##### in ".
# 4) Remove everything after the sendmail-8.x.x path component.
#
dnl # Note that the following expression only should not use double
dnl # square brackets because for some reason, possibly having to
dnl # do with the pound sign, m4 doesn't convert them to single brackets.
dnl #
ac_milter_tmp=`grep "^##### in /" /etc/mail/sendmail.cf 2> /dev/null | grep "/sendmail-8.1" | sed '1q' | sed 's,^##### in ,,' | sed 's,\(/sendmail-8\.[0-9.]*\).*,\1,'`
# Convert found version sections to three digit numbers by adding zeros.
ac_milter_found_version=`echo "$ac_milter_tmp" | sed 's,.*/sendmail-,,;s,\([[0-9]]*\),x\1x,g;s,x\([[0-9]]\)x,x0\1x,g;s,x\([[0-9]][[0-9]]\)x,x0\1x,g;s,x,,g'`
# ac_milter_version_ok will equal yes if the version is ok, otherwise no.
ac_milter_version_ok=`echo "x$ac_milter_minimum_version
x$ac_milter_found_version" | sort | sed '1q' | sed "s,x${ac_milter_minimum_version},yes,;s,x${ac_milter_found_version},no," `
if test -r "${ac_milter_tmp}/include/libmilter/mfapi.h" && \
test "$ac_milter_version_ok" = "yes" ; then
# The file mfapi.h exists so we will use this as SENDMAIL_BASE_DIR.
AC_MSG_RESULT([yes])
SENDMAIL_BASE_DIR="$ac_milter_tmp"
else
AC_MSG_RESULT([no])
fi
fi
fi
#############################################################################
#
# Determine the sendmail obj.* directory and set SENDMAIL_OBJ_DIR.
# We can only do this if we found SENDMAIL_BASE_DIR.
#
if test "x$SENDMAIL_BASE_DIR" != "x" ; then
if test "x$with_sendmail_obj" != "x" ; then
# set SENDMAIL_OBJ_DIR to the one specified by--with-sendmail-obj
SENDMAIL_OBJ_DIR="$with_sendmail_obj"
else
AC_MSG_CHECKING([for sendmail obj.* subdirectory using Build -M])
#
# --with-sendmail-obj is not used, so we will try to determine it
#
# Try to run sendmail's Build program with the -M option which will
# print out the name of the obj. directory for the tool in the
# directory where it is run from.
#
ac_milter_tmp=`(cd ${SENDMAIL_BASE_DIR}/libmilter 1> /dev/null ; ./Build -M ) 2> /dev/null`
if test -f "${ac_milter_tmp}/libmilter.a" ; then
# libmilter.a exists so this is the one we will choose
AC_MSG_RESULT([yes])
# Remove beginning and end of path from obj.* directory.
SENDMAIL_OBJ_DIR=`echo "$ac_milter_tmp" | sed 's,/libmilter$,,;s,.*/,,'`
else
AC_MSG_RESULT([no])
AC_MSG_CHECKING([for sendmail obj.* subdirectory using ls])
#
# List all directories of the form "obj." in the sendmail base
# directory, and choose the one with the latest modification date.
#
ac_milter_tmp=`ls -dt ${SENDMAIL_BASE_DIR}/obj.*/libmilter 2> /dev/null | sed '1q'`
if test -f "${ac_milter_tmp}/libmilter.a" ; then
# libmilter.a exists so this is the one we will choose
AC_MSG_RESULT([yes])
# Remove beginning and end of path from obj.* directory.
SENDMAIL_OBJ_DIR=`echo "$ac_milter_tmp" | sed 's,/libmilter$,,;s,.*/,,'`
else
AC_MSG_RESULT([no])
fi
fi
fi
fi
#############################################################################
#
# If we have both SENDMAIL_BASE_DIR and SENDMAIL_OBJ_DIR we will check
# for the necessary files.
#
if test "x$SENDMAIL_BASE_DIR" != "x" && \
test "x$SENDMAIL_OBJ_DIR" != "x" ; then
# Save and modify CPPFLAGS.
ac_milter_save_CPPFLAGS="$CPPFLAGS"
MILTER_CPPFLAGS="-I$SENDMAIL_BASE_DIR/include"
CPPFLAGS="$CPPFLAGS $MILTER_CPPFLAGS"
# Save and modify LDFLAGS.
ac_milter_save_LDFLAGS="$LDLFAGS"
MILTER_LDFLAGS="-L${SENDMAIL_BASE_DIR}/${SENDMAIL_OBJ_DIR}/libmilter"
LDFLAGS="$MILTER_LDFLAGS $LDFLAGS"
AC_CHECK_HEADER([libmilter/mfapi.h],[
AC_CHECK_LIB([milter],[smfi_main],[
# both tests succeeded so add -lmilter to the libraries to link
MILTER_LIBS="-lmilter"
# indicate success
ax_path_milter_ok=yes
])
])
# Restore the modified environment
CPPFLAGS="$ac_milter_save_CPPFLAGS"
LDFLAGS="$ac_milter_save_LDFLAGS"
fi
fi
# If failure, clear MILTER_LIBS, MILTER_LDFLAGS and MILTER_CPPFLAGS.
if test "$ax_path_milter_ok" = "no" ; then
MILTER_CPPFLAGS=""
MILTER_LIBS=""
MILTER_LDFLAGS=""
fi
# export these to the make environment
AC_SUBST([MILTER_LIBS])
AC_SUBST([MILTER_CPPFLAGS])
AC_SUBST([MILTER_LDFLAGS])
AC_SUBST([SENDMAIL_BASE_DIR])
AC_SUBST([SENDMAIL_OBJ_DIR])
# Indicate status of checking for libmilter stuff.
AC_MSG_CHECKING([if files required by libmilter are present])
# Finally, execute ACTION-IF-FOUND/ACTION-IF-NOT-FOUND.
if test "$ax_path_milter_ok" = "yes" ; then
AC_MSG_RESULT([yes])
$2
else
AC_MSG_RESULT([no])
$3
fi
])dnl