summaryrefslogtreecommitdiff
path: root/archivers/libarchive/files/configure.ac
diff options
context:
space:
mode:
Diffstat (limited to 'archivers/libarchive/files/configure.ac')
-rw-r--r--archivers/libarchive/files/configure.ac310
1 files changed, 310 insertions, 0 deletions
diff --git a/archivers/libarchive/files/configure.ac b/archivers/libarchive/files/configure.ac
new file mode 100644
index 00000000000..35af1c5e0fe
--- /dev/null
+++ b/archivers/libarchive/files/configure.ac
@@ -0,0 +1,310 @@
+#Process this file with autoconf to produce a configure script.
+
+# M4 magic to pull in the version from a separate file
+# so we don't have to edit this file for routine version updates
+m4_define([ARCHIVE_VERS],m4_include([version]))
+
+AC_INIT([libarchive],ARCHIVE_VERS(),[kientzle@freebsd.org])
+# Make sure the srcdir contains "libarchive" directory
+AC_CONFIG_SRCDIR([libarchive])
+# Use auxiliary subscripts from this subdirectory (cleans up root)
+AC_CONFIG_AUX_DIR([config.aux])
+# Must follow AC_CONFIG macros above...
+AM_INIT_AUTOMAKE()
+
+# Shell magic to compute Major/minor/etc from full version stamp.
+# This gets a little hairy...
+AC_CONFIG_COMMANDS_PRE([
+# Autoconf assigns the version above to PACKAGE_VERSION
+ARCHIVE_VERSION=$PACKAGE_VERSION
+
+# Peel off first three numbers major.minor.revision
+ARCHIVE_MAJOR=`echo $ARCHIVE_VERSION | sed -e 's/[[^0-9]]/./g' -e 's/\..*//'`
+ARCHIVE_MINOR=`echo $ARCHIVE_VERSION | sed -e 's/[[^0-9]]/./g' -e 's/^[[0-9]]*\.//' -e 's/\..*//'`
+ARCHIVE_REVISION=`echo $ARCHIVE_VERSION | sed -e 's/[[^0-9]]/./g' -e 's/^[[0-9]]*\.[[0-9]]*\.//' -e 's/\..*//'`
+# Major/minor indicate the API version
+ARCHIVE_API_MAJOR=$ARCHIVE_MAJOR
+ARCHIVE_API_MINOR=$ARCHIVE_MINOR
+ARCHIVE_VERSION_STAMP=`printf "%d%03d%03d" ${ARCHIVE_MAJOR} ${ARCHIVE_MINOR} ${ARCHIVE_REVISION}`
+# Libtool versioning uses different conventions on different platforms.
+# FreeBSD libtool still uses this old (and very dumb) convention,
+# which doesn't match FreeBSD system conventions, nor anything else
+# I'm familiar with.
+ARCHIVE_LIBTOOL_MAJOR=`echo $((${ARCHIVE_MAJOR} + ${ARCHIVE_MINOR}))`
+ARCHIVE_LIBTOOL_VERSION=$ARCHIVE_LIBTOOL_MAJOR:$ARCHIVE_REVISION:$ARCHIVE_MINOR
+])
+
+# Substitute the above version numbers into the various files below.
+AC_SUBST(ARCHIVE_VERSION)
+AC_SUBST(ARCHIVE_MAJOR)
+AC_SUBST(ARCHIVE_MINOR)
+AC_SUBST(ARCHIVE_REVISION)
+AC_SUBST(ARCHIVE_API_MAJOR)
+AC_SUBST(ARCHIVE_API_MINOR)
+AC_SUBST(ARCHIVE_VERSION_STAMP)
+AC_SUBST(ARCHIVE_LIBTOOL_VERSION)
+
+AC_CONFIG_HEADERS([config.h])
+AC_CONFIG_FILES([Makefile])
+AC_CONFIG_FILES([libarchive/archive.h])
+
+# Checks for programs.
+AC_PROG_CC
+AM_PROG_CC_C_O
+AC_PROG_YACC
+AC_PROG_LIBTOOL
+AC_CHECK_TOOL([STRIP],[strip])
+
+AC_ARG_ENABLE([bsdtar],
+ [AS_HELP_STRING([--disable-bsdtar], [disable build of bsdtar])],
+ [], [])
+
+case "$enable_bsdtar" in
+yes)
+ if test "$enable_static" = "no"; then
+ static_bsdtar=no
+ else
+ static_bsdtar=yes
+ fi
+ build_bsdtar=yes
+
+ ;;
+shared)
+ if test "$enable_shared" = "no"; then
+ AC_MSG_FAILURE([Shared linking of bsdtar requires shared libarchive])
+ fi
+ build_bsdtar=yes
+ static_bsdtar=no
+ ;;
+no)
+ build_bsdtar=no
+ static_bsdtar=no
+ ;;
+*)
+ AC_MSG_FAILURE([Unsupported value for --enable-bsdtar])
+ ;;
+esac
+
+AM_CONDITIONAL([BUILD_BSDTAR], [ test "$build_bsdtar" = yes ])
+AM_CONDITIONAL([STATIC_BSDTAR], [ test "$static_bsdtar" = yes ])
+
+# Checks for header files.
+AC_HEADER_STDC
+AC_HEADER_DIRENT
+AC_HEADER_SYS_WAIT
+AC_CHECK_HEADERS([attr/xattr.h])
+AC_CHECK_HEADERS([bzlib.h errno.h ext2fs/ext2_fs.h fcntl.h grp.h])
+AC_CHECK_HEADERS([inttypes.h langinfo.h limits.h linux/ext2_fs.h linux/fs.h])
+# Include inttypes.h into archive.h only if appropriate.
+# We can't use the HAVE_INTTYPES_H macro here because archive.h
+# gets installed as a system header and then included into client code
+# that doesn't define such macros. (And we should certainly not
+# define such macros in system headers!)
+# Hence the following:
+AC_CHECK_HEADER(inttypes.h,
+ [AC_SUBST(ARCHIVE_H_INCLUDE_INTTYPES_H,['#include <inttypes.h> /* For int64_t */'])],
+ [AC_SUBST(ARCHIVE_H_INCLUDE_INTTYPES_H,[''])])
+AC_CHECK_HEADERS([locale.h paths.h poll.h pwd.h stdarg.h])
+AC_CHECK_HEADERS([stdint.h stdlib.h string.h sys/acl.h sys/ioctl.h])
+AC_CHECK_HEADERS([sys/param.h sys/select.h sys/time.h])
+AC_CHECK_HEADERS([time.h unistd.h utime.h wchar.h zlib.h])
+
+# Checks for libraries.
+AC_CHECK_LIB(acl,acl_set_file)
+AC_CHECK_LIB(attr,setxattr)
+AC_CHECK_LIB(bz2,BZ2_bzDecompressInit)
+AC_CHECK_LIB(z,inflate)
+
+# TODO: Give the user the option of using a pre-existing system
+# libarchive. This will define HAVE_LIBARCHIVE which will cause
+# bsdtar_platform.h to use #include <...> for the libarchive headers.
+# Need to include Makefile.am magic to link against system
+# -larchive in that case.
+#AC_CHECK_LIB(archive,archive_version)
+
+# Checks for typedefs, structures, and compiler characteristics.
+AC_C_CONST
+AC_TYPE_UID_T
+AC_TYPE_MODE_T
+# AC_TYPE_OFF_T defaults to "long", which limits us to 4GB files on
+# most systems...
+AC_CHECK_TYPE(off_t, [int64_t])
+AC_TYPE_SIZE_T
+AC_CHECK_TYPE(id_t, [unsigned long])
+AC_CHECK_TYPE(uintptr_t, [unsigned int])
+AC_CHECK_MEMBERS([struct stat.st_rdev])
+AC_CHECK_MEMBERS([struct tm.tm_gmtoff])
+# Check for high-resolution timestamps in struct stat
+AC_CHECK_MEMBERS([struct stat.st_mtimespec.tv_nsec, struct stat.st_mtim.tv_nsec])
+
+#
+# We need int64_t
+#
+AC_CHECK_TYPE(int64_t)
+#
+# If int64_t isn't defined, define it in terms of some other 64-bit type.
+#
+if test "$ac_cv_type_int64_t" != yes; then
+ AC_CHECK_TYPE(_int64_t,
+ [AC_DEFINE([int64_t], [_int64_t],
+ [Define int64_t to a valid signed 64-bit type, if necessary.])])
+ if test "$ac_cv_type__int64_t" != yes; then
+ AC_CHECK_TYPE(__int64_t,
+ [AC_DEFINE([int64_t], [__int64_t],
+ [Define int64_t to a valid signed 64-bit type, if necessary.])])
+ if test "$ac_cv_type___int64_t" != yes; then
+ AC_CHECK_TYPE(long long,
+ [AC_DEFINE([int64_t], [long long],
+ [Define int64_t to a valid signed 64-bit type, if necessary.])])
+ fi
+ fi
+fi
+
+#
+# We need uint64_t
+#
+AC_CHECK_TYPE(uint64_t)
+#
+# If uint64_t isn't defined, define it in terms of some other 64-bit type.
+#
+if test "$ac_cv_type_uint64_t" != yes; then
+ AC_CHECK_TYPE(u_int64_t,
+ [AC_DEFINE([uint64_t], [u_int64_t],
+ [Define uint64_t to an unsigned 64-bit type, if necessary.])])
+ if test "$ac_cv_type_u_int64_t" != yes; then
+ AC_CHECK_TYPE(_uint64_t,
+ [AC_DEFINE([uint64_t], [_uint64_t],
+ [Define uint64_t to an unsigned 64-bit type, if necessary.])])
+ if test "$ac_cv_type__uint64_t" != yes; then
+ AC_CHECK_TYPE(__uint64_t,
+ [AC_DEFINE([uint64_t], [__uint64_t],
+ [Define uint64_t to an unsigned 64-bit type, if necessary.])])
+ if test "$ac_cv_type___uint64_t" != yes; then
+ AC_CHECK_TYPE(unsigned long long,
+ [AC_DEFINE([uint64_t], [unsigned long long],
+ [Define uint64_t to an unsigned 64-bit type, if necessary.])])
+ fi
+ fi
+ fi
+fi
+
+# We need uintmax_t and intmax_t
+# Define them in terms of uint64_t and int64_t if appropriate.
+AC_CHECK_TYPE(uintmax_t, [uint64_t])
+AC_CHECK_TYPE(intmax_t, [int64_t])
+
+
+# If you have uintmax_t, we assume printf supports %ju
+# If you have unsigned long long, we assume printf supports %llu
+AC_CHECK_TYPES([uintmax_t, unsigned long long])
+
+# TODO: If any of these are missing, define them right here.
+AC_CHECK_DECLS([SIZE_MAX, INT64_MAX, INT64_MIN, UINT64_MAX, UINT32_MAX])
+
+AC_CHECK_DECL([EFTYPE],
+ [AC_DEFINE(HAVE_EFTYPE, 1, [A possible errno value for invalid file format errors])],
+ [],
+ [#include <errno.h>])
+AC_CHECK_DECL([EILSEQ],
+ [AC_DEFINE(HAVE_EILSEQ, 1, [A possible errno value for invalid file format errors])],
+ [],
+ [#include <errno.h>])
+AC_HEADER_TIME
+
+# Checks for library functions.
+AC_PROG_GCC_TRADITIONAL
+AC_HEADER_MAJOR
+AC_FUNC_FSEEKO
+AC_FUNC_MEMCMP
+AC_FUNC_LSTAT
+AC_FUNC_STAT
+AC_FUNC_STRERROR_R
+AC_FUNC_STRFTIME
+AC_FUNC_VPRINTF
+AC_CHECK_FUNCS([chflags fchdir fchflags fchmod fchown futimes])
+AC_CHECK_FUNCS([ftruncate getopt_long getxattr])
+AC_CHECK_FUNCS([lchflags lchmod lchown])
+AC_CHECK_FUNCS([lgetxattr listxattr llistxattr fsetxattr lsetxattr])
+AC_CHECK_FUNCS([lutimes memmove memset mkdir mkfifo])
+AC_CHECK_FUNCS([nl_langinfo poll reallocf select setlocale])
+AC_CHECK_FUNCS([strchr strdup strerror strrchr timegm utime utimes])
+AC_CHECK_FUNCS([wcscpy wcslen wmemcmp wmemcpy])
+
+# FreeBSD's nl_langinfo supports an option to specify whether the
+# current locale uses month/day or day/month ordering. It makes the
+# output a little prettier...
+AC_CHECK_DECL([D_MD_ORDER],
+[AC_DEFINE(HAVE_D_MD_ORDER, 1, [Define to 1 if nl_langinfo supports D_MD_ORDER])],
+[],
+[#if HAVE_LANGINFO_H
+#include <langinfo.h>
+#endif
+])
+
+# If fnmatch() exists and supports FNM_LEADING_DIR, then bsdtar uses that,
+# otherwise it uses some usable (but less featureful) built-in code for
+# filename pattern matching.
+AC_FUNC_FNMATCH
+AC_CHECK_DECL([FNM_LEADING_DIR],
+[AC_DEFINE(HAVE_FNM_LEADING_DIR, 1, [Define to 1 if fnmatch(3) supports the FNM_LEADING_DIR flag])],
+[],
+[#if HAVE_FNMATCH
+#define _GNU_SOURCE /* Required on Linux to get GNU extensions */
+#include <fnmatch.h>
+#endif
+])
+
+# Check for dirent.d_namlen field explicitly
+# (This is a bit more straightforward than, if not quite as portable as,
+# the recipe given by the autoconf maintainers.)
+AC_CHECK_MEMBER(struct dirent.d_namlen,,,
+[#if HAVE_DIRENT_H
+#include <dirent.h>
+#endif
+])
+
+# Check for ACL support
+#
+# The ACL support in libarchive is written against the POSIX1e draft,
+# which was never officially approved and varies quite a bit across
+# platforms. Worse, some systems have completely non-POSIX acl functions,
+# which makes the following checks rather more complex than I would like.
+#
+AC_CHECK_HEADERS([sys/acl.h])
+AC_CHECK_LIB([acl],[acl_get_file])
+AC_CHECK_FUNCS([acl_create_entry acl_init acl_set_fd acl_set_fd_np acl_set_file])
+
+AC_CHECK_TYPES(acl_permset_t,,,
+[#if HAVE_SYS_TYPES_H
+#include <sys/types.h>
+#endif
+#if HAVE_SYS_ACL_H
+#include <sys/acl.h>
+#endif
+])
+
+# The "acl_get_perm()" function was omitted from the POSIX draft.
+# (It's a pretty obvious oversight; otherwise, there's no way to
+# test for specific permissions in a permset.) Linux uses the obvious
+# name, FreeBSD adds _np to mark it as "non-Posix extension."
+# Test for both as a double-check that we really have POSIX-style ACL support.
+AC_CHECK_FUNCS(acl_get_perm_np acl_get_perm,,,
+[#if HAVE_SYS_TYPES_H
+#include <sys/types.h>
+#endif
+#if HAVE_SYS_ACL_H
+#include <sys/acl.h>
+#endif
+])
+
+# MacOS has an acl.h that isn't POSIX. It can be detected by
+# checking for ACL_USER
+AC_CHECK_DECL([ACL_USER],
+ [AC_DEFINE(HAVE_ACL_USER, 1, [True for systems with POSIX ACL support])],
+ [],
+ [#include <sys/acl.h>])
+
+# Additional requirements
+AC_SYS_LARGEFILE
+
+AC_OUTPUT