diff options
Diffstat (limited to '')
-rw-r--r-- | m4/dpkg-funcs.m4 | 216 |
1 files changed, 216 insertions, 0 deletions
diff --git a/m4/dpkg-funcs.m4 b/m4/dpkg-funcs.m4 new file mode 100644 index 0000000..c480c10 --- /dev/null +++ b/m4/dpkg-funcs.m4 @@ -0,0 +1,216 @@ +# serial 1 +# Copyright © 2005 Scott James Remnant <scott@netsplit.com> +# Copyright © 2008-2009,2015 Guillem Jover <guillem@debian.org> + +# DPKG_FUNC_VA_COPY +# ----------------- +# Define HAVE_VA_COPY if we have va_copy. +AC_DEFUN([DPKG_FUNC_VA_COPY], [ + AC_CACHE_CHECK([for va_copy], [dpkg_cv_va_copy], [ + AC_COMPILE_IFELSE([ + AC_LANG_PROGRAM([[ +#include <stdarg.h> + ]], [[ +va_list v1, v2; +va_copy(v1, v2); + ]]) + ], [ + dpkg_cv_va_copy=yes + ], [ + dpkg_cv_va_copy=no + ]) + ]) + AS_IF([test "x$dpkg_cv_va_copy" = "xyes"], [ + AC_DEFINE([HAVE_VA_COPY], [1], [Define to 1 if the 'va_copy' macro exists]) + ]) +])# DPKG_FUNC_VA_COPY + +# DPKG_FUNC_FSYNC_DIR +# ------------------- +# Define HAVE_FSYNC_DIR if we can fsync(2) directories. +AC_DEFUN([DPKG_FUNC_FSYNC_DIR], [ + AC_CACHE_CHECK([whether fsync works on directories], [dpkg_cv_fsync_dir], [ + AC_RUN_IFELSE([ + AC_LANG_PROGRAM([[ +#include <sys/types.h> +#include <stddef.h> +#include <dirent.h> +#include <unistd.h> + ]], [[ + int fd; + DIR *dir = opendir("."); + if (dir == NULL) + return 1; + fd = dirfd(dir); + if (fd < 0) + return 1; + if (fsync(fd) < 0) + return 1; + closedir(dir); + ]]) + ], [ + dpkg_cv_fsync_dir=yes + ], [ + dpkg_cv_fsync_dir=no + ], [ + dpkg_cv_fsync_dir=maybe + ]) + + AS_IF([test "x$dpkg_cv_fsync_dir" = "xmaybe"], [ + AS_CASE([$host_os], + [aix*], [ + # On AIX fsync(3) requires writable file descriptors, which + # opendir(3) does not provide, but even then fsync(3) nor + # fsync_range(3) always work on directories anyway. + dpkg_cv_fsync_dir=no + ], [ + # On other systems we assume this works. + dpkg_cv_fsync_dir=yes + ] + ) + ]) + ]) + AS_IF([test "x$dpkg_cv_fsync_dir" = "xyes"], [ + AC_DEFINE([HAVE_FSYNC_DIR], [1], + [Define to 1 if the 'fsync' function works on directories]) + ]) +]) + +# DPKG_FUNC_C99_SNPRINTF +# ----------------------- +# Define HAVE_C99_SNPRINTF if we have C99 snprintf family semantics +AC_DEFUN([DPKG_FUNC_C99_SNPRINTF], [ + AC_CACHE_CHECK([for C99 snprintf functions], [dpkg_cv_c99_snprintf], [ + AC_RUN_IFELSE([ + AC_LANG_PROGRAM([[ +#include <stdarg.h> +#include <stdio.h> +#include <string.h> +int test_vsnprintf(const char *fmt, ...) +{ + int n; + va_list args; + + va_start(args, fmt); + n = vsnprintf(NULL, 0, fmt, args); + va_end(args); + + return n; +} + ]], [[ + int n; + + n = snprintf(NULL, 0, "format %s %d", "string", 10); + if (n != strlen("format string 10")) + return 1; + + n = test_vsnprintf("format %s %d", "string", 10); + if (n != strlen("format string 10")) + return 1; + ]]) + ], [ + dpkg_cv_c99_snprintf=yes + ], [ + dpkg_cv_c99_snprintf=no + ], [ + dpkg_cv_c99_snprintf=maybe + ]) + + AS_IF([test "x$dpkg_cv_c99_snprintf" = "xmaybe"], [ + AC_COMPILE_IFELSE([ + AC_LANG_SOURCE([[ +#define _GNU_SOURCE 1 +#include <unistd.h> +#if !defined(_XOPEN_VERSION) || _XOPEN_VERSION < 600 +#error "snprintf() has conflicting semantics with C99 on SUSv2 and earlier" +#endif + ]]) + ], [ + dpkg_cv_c99_snprintf=yes + ], [ + dpkg_cv_c99_snprintf=no + ]) + ]) + ]) + AS_IF([test "x$dpkg_cv_c99_snprintf" = "xyes"], [ + AC_DEFINE([HAVE_C99_SNPRINTF], [1], + [Define to 1 if the 'snprintf' family is C99 conformant]) + ]) + AM_CONDITIONAL([HAVE_C99_SNPRINTF], [test "x$dpkg_cv_c99_snprintf" = "xyes"]) +])# DPKG_FUNC_C99_SNPRINTF + +# DPKG_USE_MMAP +# ------------- +# Define USE_MMAP if mmap() is available and it was requested +AC_DEFUN([DPKG_USE_MMAP], [ + AC_ARG_ENABLE([mmap], + [AS_HELP_STRING([--enable-mmap], + [enable usage of unrealiable mmap if available])], + [], [enable_mmap=no]) + + AS_IF([test "x$enable_mmap" = "xyes"], [ + AC_CHECK_FUNCS([mmap]) + AC_DEFINE([USE_MMAP], [1], [Use unreliable mmap support]) + ]) +]) + +# DPKG_USE_DISK_PREALLOCATE +# ------------------------- +# Define USE_DISK_PREALLOCATE if disk size pre-allocation is available +# and it was requested. +AC_DEFUN([DPKG_USE_DISK_PREALLOCATE], [ + AC_ARG_ENABLE([disk-preallocate], + [AS_HELP_STRING([--enable-disk-preallocate], + [enable usage of disk size pre-allocation])], + [], [enable_disk_preallocate=no]) + + AS_IF([test "x$enable_disk_preallocate" = "xyes"], [ + AC_DEFINE([USE_DISK_PREALLOCATE], [1], [Use disk size pre-allocation]) + ]) +]) + +# DPKG_CHECK_PROGNAME +# ------------------- +# Check for system implementations of program name tracking. +AC_DEFUN([DPKG_CHECK_PROGNAME], [ + AC_MSG_CHECKING([for program_invocation_short_name]) + AC_LINK_IFELSE([ + AC_LANG_PROGRAM([[ +#include <errno.h> + ]], [[ +const char *p = program_invocation_short_name; + ]]) + ], [ + AC_DEFINE([HAVE_PROGRAM_INVOCATION_SHORT_NAME], [1], + [Define to 1 if you have program_invocation_short_name]) + AC_MSG_RESULT([yes]) + ], [ + AC_MSG_RESULT([no]) + ]) + + AC_MSG_CHECKING([for __progname]) + AC_LINK_IFELSE([ + AC_LANG_PROGRAM([[ +#include <stdio.h> +extern char *__progname; + ]], [[ +printf("%s", __progname); + ]]) + ], [ + AC_DEFINE([HAVE___PROGNAME], [1], [Define to 1 if you have __progname]) + AC_MSG_RESULT([yes]) + ], [ + AC_MSG_RESULT([no]) + ]) +]) # DPKG_CHECK_PROGNAME + +# DPKG_CHECK_COMPAT_FUNCS(LIST) +# ----------------------- +# Check each function and define an automake conditional +AC_DEFUN([DPKG_CHECK_COMPAT_FUNCS], [ + AC_CHECK_FUNCS([$1]) + m4_foreach_w([ac_func], [$1], [ + AM_CONDITIONAL([HAVE_]AS_TR_CPP(ac_func), + [test "x$ac_cv_func_[]AS_TR_SH(ac_func)" = "xyes"]) + ]) +]) # DPKG_CHECK_COMPAT_FUNCS |