diff options
author | Jim Meyering <jim@meyering.net> | 2002-04-12 20:48:29 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2002-04-12 20:48:29 +0000 |
commit | 50bc2a428665bddda5baa6718adb48bce14833c3 (patch) | |
tree | d34a235c3bd0d9959438a90ed546167171ea836e /m4/dirfd.m4 | |
parent | 7f01432879050804d18202f93cd5e6cd0ff125da (diff) | |
download | coreutils-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.m4 | 18 |
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*], |