summaryrefslogtreecommitdiff
path: root/m4/dirfd.m4
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2002-04-12 20:48:29 +0000
committerJim Meyering <jim@meyering.net>2002-04-12 20:48:29 +0000
commit50bc2a428665bddda5baa6718adb48bce14833c3 (patch)
treed34a235c3bd0d9959438a90ed546167171ea836e /m4/dirfd.m4
parent7f01432879050804d18202f93cd5e6cd0ff125da (diff)
downloadcoreutils-50bc2a428665bddda5baa6718adb48bce14833c3.tar.xz
(UTILS_FUNC_DIRFD): Also detect when dirfd is a macro.
This is necessary at least on Darwin 5.3.
Diffstat (limited to 'm4/dirfd.m4')
-rw-r--r--m4/dirfd.m418
1 files changed, 14 insertions, 4 deletions
diff --git a/m4/dirfd.m4 b/m4/dirfd.m4
index f18bf80f8..efdd06718 100644
--- a/m4/dirfd.m4
+++ b/m4/dirfd.m4
@@ -1,4 +1,4 @@
-#serial 1
+#serial 2
dnl Find out how to get the file descriptor associated with an open DIR*.
dnl From Jim Meyering
@@ -25,9 +25,19 @@ AC_DEFUN([UTILS_FUNC_DIRFD],
AC_CHECK_FUNCS(dirfd)
AC_CHECK_DECLS([dirfd], , , $dirfd_headers)
- # Use the replacement only if we have neither the function
- # nor a declaration.
- if test $ac_cv_func_dirfd,$ac_cv_have_decl_dirfd = no,no; then
+ AC_CACHE_CHECK([whether dirfd is a macro],
+ jm_cv_func_dirfd_macro,
+ AC_EGREP_CPP([dirent_header_defines_dirfd], [$dirfd_headers
+#ifdef dirfd
+ dirent_header_defines_dirfd
+#endif],
+ jm_cv_func_dirfd_macro=yes,
+ jm_cv_func_dirfd_macro=no))
+
+ # Use the replacement only if we have no function, macro,
+ # or declaration with that name.
+ if test $ac_cv_func_dirfd,$ac_cv_have_decl_dirfd,$jm_cv_func_dirfd_macro \
+ = no,no,no; then
AC_REPLACE_FUNCS([dirfd])
AC_CACHE_CHECK(
[how to get the file descriptor associated with an open DIR*],