From: Jim Meyering Date: Sun, 16 Sep 2001 12:32:07 +0000 (+0000) Subject: (UTILS_FUNC_MKDIR_TRAILING_SLASH): New file/macro. X-Git-Tag: TEXTUTILS-2_0_15~81 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=0b0b0c10b9ced9264268c64670c391329cbafedd;p=thirdparty%2Fcoreutils.git (UTILS_FUNC_MKDIR_TRAILING_SLASH): New file/macro. --- diff --git a/m4/mkdir-slash.m4 b/m4/mkdir-slash.m4 new file mode 100644 index 0000000000..8245d88706 --- /dev/null +++ b/m4/mkdir-slash.m4 @@ -0,0 +1,35 @@ +#serial 1 + +# On some systems, mkdir ("foo/", 0700) fails because of the trailing slash. +# On such systems, arrange to use a wrapper function that removes any +# trailing slashes. +AC_DEFUN([UTILS_FUNC_MKDIR_TRAILING_SLASH], +[dnl + AC_CACHE_CHECK([whether mkdir fails due to a trailing slash], + utils_cv_func_mkdir_trailing_slash_bug, + [ + # Arrange for deletion of the temporary directory this test might create. + ac_clean_files="$ac_clean_files confdir-slash" + AC_TRY_RUN([ +# include +# include +# include + int main () + { + rmdir ("confdir-slash"); + exit (mkdir ("confdir-slash/", 0700)); + } + ], + utils_cv_func_mkdir_trailing_slash_bug=no, + utils_cv_func_mkdir_trailing_slash_bug=yes, + utils_cv_func_mkdir_trailing_slash_bug=yes + ) + ] + ) + + if test $utils_cv_func_mkdir_trailing_slash_bug = yes; then + AC_LIBOBJ(mkdir) + AC_DEFINE_UNQUOTED(mkdir, rpl_mkdir, + [Define to rpl_mkdir if the replacement function should be used.]) + fi +])