summaryrefslogtreecommitdiffstats
path: root/configure.ac
diff options
context:
space:
mode:
Diffstat (limited to 'configure.ac')
-rw-r--r--configure.ac107
1 files changed, 107 insertions, 0 deletions
diff --git a/configure.ac b/configure.ac
new file mode 100644
index 0000000..5d16851
--- /dev/null
+++ b/configure.ac
@@ -0,0 +1,107 @@
+m4_define([cryptopANT_major_version], [1])
+m4_define([cryptopANT_minor_version], [3])
+m4_define([cryptopANT_micro_version], [1])
+m4_define([cryptopANT_version], [cryptopANT_major_version.cryptopANT_minor_version.cryptopANT_micro_version])
+
+#format: current:revision:age
+#If the library source code has changed at all since the last update, then increment revision (‘c:r:a’ becomes ‘c:r+1:a’).
+#If any interfaces have been added, removed, or changed since the last update, increment current, and set revision to 0.
+#If any interfaces have been added since the last public release, then increment age.
+#If any interfaces have been removed or changed since the last public release, then set age to 0.
+#see also https://autotools.io/libtool/version.html
+m4_define([cryptopANT_library_version], ["1:4:0"])
+
+AC_INIT([cryptopANT], [cryptopANT_version], [ant@isi.edu], [cryptopANT])
+dnl m4_pattern_allow(AC_CONFIG_MACRO_DIRS)
+AC_CONFIG_MACRO_DIR([m4])
+AC_CONFIG_HEADERS([src/config.h])
+AC_PROG_CC
+AC_C_BIGENDIAN()
+AM_PROG_CC_C_O
+
+# Check headers
+AC_CHECK_HEADERS([openssl/blowfish.h], HAVE_OPENSSL=1, HAVE_OPENSSL=0)
+AC_CHECK_HEADERS([openssl/sha.h],, HAVE_OPENSSL=0)
+AC_CHECK_HEADERS([openssl/aes.h],, HAVE_OPENSSL=0)
+AC_CHECK_HEADERS([openssl/md5.h],, HAVE_OPENSSL=0)
+AC_CHECK_HEADERS([openssl/evp.h],, HAVE_OPENSSL=0)
+AC_CHECK_HEADERS([openssl/provider.h],, HAVE_OPENSSL=0)
+AC_CHECK_HEADERS([openssl/err.h],, HAVE_OPENSSL=0)
+AC_CHECK_HEADERS([openssl/core_names.h],, HAVE_OPENSSL=0)
+
+# Check for POSIX regular expressions support.
+AC_CHECK_HEADERS([regex.h], HAVE_REGEX_H=1, HAVE_REGEX_H=0)
+
+if test "x$HAVE_REGEX_H" = "x1"; then
+ AC_CHECK_FUNCS([regcomp regexec],, HAVE_REGEX=0)
+else
+ HAVE_REGEX=0
+fi
+if test "x$HAVE_REGEX_H" = "x0"; then
+ AC_MSG_FAILURE([regex library is not found: make sure glibc-devel is installed])
+fi
+if test "x$HAVE_OPENSSL_H" = "x0"; then
+ AC_MSG_FAILURE([ssl is not found: make sure openssl-devel is installed])
+fi
+AC_CHECK_LIB([crypto], [EVP_CIPHER_CTX_new],, HAVE_OPENSSL=0)
+AC_CHECK_LIB([crypto], [EVP_MD_CTX_new],, HAVE_OPENSSL=0)
+if test "x$HAVE_OPENSSL" = "x0"; then
+ AC_MSG_FAILURE([ssl is not found: make sure openssl library version 3.1.0 or higher is installed])
+fi
+
+AC_DEFINE([HAVE_S6_ADDR32], [0], [S6_ADDR32 is present in in6_addr when defined])
+AC_DEFINE([HAVE__U6_ADDR32], [0], [U6_ADDR32 is present in in6_addr when defined])
+AC_CHECK_MEMBER([struct in6_addr.s6_addr32],
+ [AC_DEFINE([HAVE_S6_ADDR32], [1])],
+ [
+ AC_CHECK_MEMBER([struct in6_addr.__u6_addr.__u6_addr32],
+ [AC_DEFINE([HAVE__U6_ADDR32], [1])],
+ [AC_MSG_ERROR([CAN'T find s6_addr32])],
+ [#include <netinet/in.h>])
+ ], [#include <netinet/in.h>])
+
+AC_CHECK_FUNCS([strlcpy])
+
+AC_C_CONST
+AC_TYPE_SIZE_T
+AC_TYPE_UINT32_T
+
+# Check --enable-warn-all
+AC_ARG_ENABLE([warn-all], [AS_HELP_STRING([--enable-warn-all], [Enable all compiler warnings])], [AX_CFLAGS_WARN_ALL()])
+
+# Check --with-extra-cflags
+AC_ARG_WITH([extra-cflags], [AS_HELP_STRING([--with-extra-cflags=CFLAGS], [Add extra CFLAGS])], [
+ AC_MSG_NOTICE([appending extra CFLAGS... $withval])
+ AS_VAR_APPEND(CFLAGS, [" $withval"])
+])
+
+# Check --with-extra-ldflags
+AC_ARG_WITH([extra-ldflags], [AS_HELP_STRING([--with-extra-ldflags=CFLAGS], [Add extra LDFLAGS])], [
+ AC_MSG_NOTICE([appending extra LDFLAGS... $withval])
+ AS_VAR_APPEND(LDFLAGS, [" $withval"])
+])
+
+# Check --with-scramble_ips
+build_scramble_ips=no
+AC_ARG_WITH([scramble_ips], [AS_HELP_STRING([--with-scramble_ips], [Also build scramble_ips tool])], [
+ build_scramble_ips=$withval
+ AS_IF([test "x$build_scramble_ips" = "xyes"],
+ [AC_MSG_NOTICE([Building tool "scramble_ips"])],
+ [AC_MSG_NOTICE([Not building tool "scramble_ips"])]
+ )
+])
+AM_CONDITIONAL([BUILD_SCRAMBLE_IPS], [test "x$build_scramble_ips" = "xyes"])
+
+AC_CONFIG_FILES([Makefile cryptopANT.spec])
+AC_ENABLE_SHARED
+AC_ENABLE_STATIC
+AM_INIT_AUTOMAKE([-Wall -Werror foreign subdir-objects])
+m4_ifdef([AM_PROG_AR], [AM_PROG_AR])
+LT_INIT
+
+AC_SUBST([PACKAGE_VERSION], [cryptopANT_version])
+AC_SUBST([PACKAGE_VERSION_MAJOR], [cryptopANT_major_version])
+AC_SUBST([PACKAGE_VERSION_MINOR], [cryptopANT_minor_version])
+AC_SUBST([PACKAGE_VERSION_MICRO], [cryptopANT_micro_version])
+AC_SUBST([CRYPTOPANT_LIBRARY_VERSION], [cryptopANT_library_version])
+AC_OUTPUT