summaryrefslogtreecommitdiffstats
path: root/m4/mkfifoat.m4
diff options
context:
space:
mode:
Diffstat (limited to 'm4/mkfifoat.m4')
-rw-r--r--m4/mkfifoat.m473
1 files changed, 73 insertions, 0 deletions
diff --git a/m4/mkfifoat.m4 b/m4/mkfifoat.m4
new file mode 100644
index 0000000..2654050
--- /dev/null
+++ b/m4/mkfifoat.m4
@@ -0,0 +1,73 @@
+# serial 10
+# See if we need to provide mkfifoat/mknodat replacement.
+
+dnl Copyright (C) 2009-2023 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+
+# Written by Eric Blake.
+
+AC_DEFUN([gl_FUNC_MKFIFOAT],
+[
+ AC_REQUIRE([gl_SYS_STAT_H_DEFAULTS])
+ AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles
+
+ dnl Persuade glibc <sys/stat.h> to declare mkfifoat() and mknodat().
+ AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS])
+
+ AC_REQUIRE([gl_FUNC_OPENAT])
+
+ gl_CHECK_FUNCS_ANDROID_MACOS([mknodat], [[#include <sys/stat.h>]])
+ gl_CHECK_FUNCS_ANDROID_MACOS([mkfifoat], [[#include <sys/stat.h>]])
+ if test $ac_cv_func_mkfifoat = yes; then
+ dnl Check for AIX 7.2 bug with trailing slash.
+ AC_CACHE_CHECK([whether mkfifoat rejects trailing slashes],
+ [gl_cv_func_mkfifoat_works],
+ [rm -f conftest.tmp
+ AC_RUN_IFELSE(
+ [AC_LANG_PROGRAM(
+ [[#include <fcntl.h>
+ #include <sys/stat.h>
+ ]],
+ [[int result = 0;
+ if (!mkfifoat (AT_FDCWD, "conftest.tmp/", 0600))
+ result |= 1;
+ return result;
+ ]])
+ ],
+ [gl_cv_func_mkfifoat_works=yes],
+ [gl_cv_func_mkfifoat_works=no],
+ [case "$host_os" in
+ # Guess yes on Linux systems.
+ linux-* | linux) gl_cv_func_mkfifoat_works="guessing yes" ;;
+ # Guess yes on glibc systems.
+ *-gnu* | gnu*) gl_cv_func_mkfifoat_works="guessing yes" ;;
+ # Guess no on AIX systems.
+ aix*) gl_cv_func_mkfifoat_works="guessing no" ;;
+ # If we don't know, obey --enable-cross-guesses.
+ *) gl_cv_func_mkfifoat_works="$gl_cross_guess_normal" ;;
+ esac
+ ])
+ rm -f conftest.tmp
+ ])
+ case "$gl_cv_func_mkfifoat_works" in
+ *yes) ;;
+ *)
+ REPLACE_MKFIFOAT=1
+ dnl mknodat() has the same bug as mkfifoat().
+ REPLACE_MKNODAT=1
+ ;;
+ esac
+ else
+ # No known system has mkfifoat but not mknodat
+ HAVE_MKFIFOAT=0
+ case "$gl_cv_onwards_func_mkfifoat" in
+ future*) REPLACE_MKFIFOAT=1 ;;
+ esac
+ HAVE_MKNODAT=0
+ case "$gl_cv_onwards_func_mknodat" in
+ future*) REPLACE_MKNODAT=1 ;;
+ esac
+ fi
+])