X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fchown.m4;h=86c5fc7545cb79a6f5b8f384db9c8c329efc403b;hb=30ffdfca0db8e3dede862ce911a200ecc1894fd5;hp=deae13b4176a058bb18ddb10712cfe24281877cc;hpb=2f209fdc6f93ca7ce1f736811779a9371a03f7e4;p=gnulib.git diff --git a/m4/chown.m4 b/m4/chown.m4 index deae13b41..86c5fc754 100644 --- a/m4/chown.m4 +++ b/m4/chown.m4 @@ -1,50 +1,24 @@ -#serial 4 +#serial 8 dnl From Jim Meyering. dnl Determine whether chown accepts arguments of -1 for uid and gid. dnl If it doesn't, arrange to use the replacement function. dnl -AC_DEFUN(jm_FUNC_CHOWN, -[AC_REQUIRE([AC_TYPE_UID_T])dnl - test -z "$ac_cv_header_unistd_h" \ - && AC_CHECK_HEADERS(unistd.h) - AC_CACHE_CHECK([for working chown], jm_cv_func_working_chown, - [AC_TRY_RUN([ -# include -# include -# include -# ifdef HAVE_UNISTD_H -# include -# endif - - int - main () - { - char *f = "conftestchown"; - struct stat before, after; - - if (creat (f, 0600) < 0) - exit (1); - if (stat (f, &before) < 0) - exit (1); - if (chown (f, (uid_t) -1, (gid_t) -1) == -1) - exit (1); - if (stat (f, &after) < 0) - exit (1); - exit ((before.st_uid == after.st_uid - && before.st_gid == after.st_gid) ? 0 : 1); - } - ], - jm_cv_func_working_chown=yes, - jm_cv_func_working_chown=no, - dnl When crosscompiling, assume chown is broken. - jm_cv_func_working_chown=no) - ]) - if test $jm_cv_func_working_chown = no; then - AC_SUBST(LIBOBJS) - LIBOBJS="$LIBOBJS chown.$ac_objext" - AC_DEFINE_UNQUOTED(chown, rpl_chown, +AC_DEFUN([jm_FUNC_CHOWN], +[ + AC_REQUIRE([AC_TYPE_UID_T])dnl + AC_REQUIRE([AC_FUNC_CHOWN]) + if test $ac_cv_func_chown_works = no; then + AC_LIBOBJ(chown) + AC_DEFINE(chown, rpl_chown, [Define to rpl_chown if the replacement function should be used.]) + gl_PREREQ_CHOWN fi ]) + +# Prerequisites of lib/chown.c. +AC_DEFUN([gl_PREREQ_CHOWN], +[ + AC_CHECK_HEADERS_ONCE(unistd.h) +])