From bf1550b6f8387fe892c6e6e1c86316634a0604ae Mon Sep 17 00:00:00 2001 From: Christopher Faylor Date: Wed, 12 Oct 2005 20:38:38 +0000 Subject: * dir.cc (mkdir): Abandon use of PC_WRITABLE. (rmdir): Ditto. * path.h (PC_WRITABLE): Delete. * path.cc (path_conv::check): Remove PC_WRITABLE accommodations. Revisit later. --- winsup/cygwin/dir.cc | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'winsup/cygwin/dir.cc') diff --git a/winsup/cygwin/dir.cc b/winsup/cygwin/dir.cc index c6b318edd..0d25619b9 100644 --- a/winsup/cygwin/dir.cc +++ b/winsup/cygwin/dir.cc @@ -265,7 +265,7 @@ mkdir (const char *dir, mode_t mode) return -1; } - if (!(fh = build_fh_name (dir, NULL, PC_SYM_NOFOLLOW | PC_WRITABLE))) + if (!(fh = build_fh_name (dir, NULL, PC_SYM_NOFOLLOW))) goto done; /* errno already set */; if (fh->error ()) @@ -299,13 +299,16 @@ rmdir (const char *dir) return -1; } - if (!(fh = build_fh_name (dir, NULL, PC_SYM_NOFOLLOW | PC_WRITABLE))) + if (!(fh = build_fh_name (dir, NULL, PC_SYM_NOFOLLOW))) goto done; /* errno already set */; if (fh->error ()) { debug_printf ("got %d error from build_fh_name", fh->error ()); - set_errno (fh->error ()); + if (fh->error ()) + set_errno (EROFS); + else + set_errno (fh->error ()); } else if (!fh->rmdir ()) res = 0; -- cgit v1.2.3