From: Paul Eggert Date: Thu, 22 Sep 2005 05:42:26 +0000 (+0000) Subject: (ENOSYS): Define to EEXIST if not defined. X-Git-Tag: v5.90~158 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=0adb008b03d39a3e288944b79c337cf39ad768b2;p=thirdparty%2Fcoreutils.git (ENOSYS): Define to EEXIST if not defined. (make_dir_parents): Treat ENOSYS like EEXIST. --- diff --git a/lib/mkdir-p.c b/lib/mkdir-p.c index 315a3a06a9..b074c0aa78 100644 --- a/lib/mkdir-p.c +++ b/lib/mkdir-p.c @@ -19,7 +19,7 @@ /* Written by David MacKenzie and Jim Meyering. */ -#if HAVE_CONFIG_H +#ifdef HAVE_CONFIG_H # include #endif @@ -45,6 +45,10 @@ #include "quote.h" #include "stat-macros.h" +#ifndef ENOSYS +# define ENOSYS EEXIST +#endif + #define WX_USR (S_IWUSR | S_IXUSR) /* Ensure that the directory ARG exists. @@ -211,10 +215,14 @@ make_dir_parents (char const *arg, leading_dirs = new; } } - else if (errno == EEXIST) + else if (errno == EEXIST || errno == ENOSYS) { /* A file is already there. Perhaps it is a directory. - If not, it will be diagnosed later. */ + If not, it will be diagnosed later. + + The ENOSYS is for Solaris 8 NFS clients, which can + fail with errno == ENOSYS if mkdir is invoked on an + NFS mount point. */ } else {