Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2004-01-26 02:39:26 +0300
committerChristopher Faylor <me@cgf.cx>2004-01-26 02:39:26 +0300
commitd7231d7224e004dc29640222f4d08da7b15aacce (patch)
treed4865998d9faa9dec71c21cce23b391bc359065b /winsup/cygwin/fhandler.cc
parent6bc774fc6bfe3c69b1ca488b5d126c7ee47bf5fe (diff)
* fhandler.cc (fhandler_base::fhaccess): Avoid always setting errno to EACCESS
when return value is < 0. Rely on errno being set properly.
Diffstat (limited to 'winsup/cygwin/fhandler.cc')
-rw-r--r--winsup/cygwin/fhandler.cc31
1 files changed, 17 insertions, 14 deletions
diff --git a/winsup/cygwin/fhandler.cc b/winsup/cygwin/fhandler.cc
index 38b95d42b..2b86d3c51 100644
--- a/winsup/cygwin/fhandler.cc
+++ b/winsup/cygwin/fhandler.cc
@@ -353,12 +353,12 @@ fhandler_base::fhaccess (int flags)
if (is_fs_special ())
/* short circuit */;
else if (has_attribute (FILE_ATTRIBUTE_READONLY) && (flags & W_OK))
+ goto eaccess_done;
+ else if (has_acls () && allow_ntsec)
{
- set_errno (EACCES);
+ res = check_file_access (get_win32_name (), flags);
goto done;
}
- else if (has_acls () && allow_ntsec)
- return check_file_access (get_win32_name (), flags);
struct __stat64 st;
if (fstat (&st))
@@ -369,15 +369,15 @@ fhandler_base::fhaccess (int flags)
if (st.st_uid == myself->uid)
{
if (!(st.st_mode & S_IRUSR))
- goto done;
+ goto eaccess_done;
}
else if (st.st_gid == myself->gid)
{
if (!(st.st_mode & S_IRGRP))
- goto done;
+ goto eaccess_done;
}
else if (!(st.st_mode & S_IROTH))
- goto done;
+ goto eaccess_done;
}
if (flags & W_OK)
@@ -385,15 +385,15 @@ fhandler_base::fhaccess (int flags)
if (st.st_uid == myself->uid)
{
if (!(st.st_mode & S_IWUSR))
- goto done;
+ goto eaccess_done;
}
else if (st.st_gid == myself->gid)
{
if (!(st.st_mode & S_IWGRP))
- goto done;
+ goto eaccess_done;
}
else if (!(st.st_mode & S_IWOTH))
- goto done;
+ goto eaccess_done;
}
if (flags & X_OK)
@@ -401,20 +401,23 @@ fhandler_base::fhaccess (int flags)
if (st.st_uid == myself->uid)
{
if (!(st.st_mode & S_IXUSR))
- goto done;
+ goto eaccess_done;
}
else if (st.st_gid == myself->gid)
{
if (!(st.st_mode & S_IXGRP))
- goto done;
+ goto eaccess_done;
}
else if (!(st.st_mode & S_IXOTH))
- goto done;
+ goto eaccess_done;
}
+
res = 0;
+ goto done;
+
+eaccess_done:
+ set_errno (EACCES);
done:
- if (res)
- set_errno (EACCES);
debug_printf ("returning %d", res);
return res;
}