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
path: root/winsup
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2002-05-31 04:15:22 +0400
committerChristopher Faylor <me@cgf.cx>2002-05-31 04:15:22 +0400
commit5d8c7a56c287079c59491f3dee8e33e05cefdf45 (patch)
tree7d09f9c81e5466f437202c5a6bc273c3939499bb /winsup
parent53e05aecc10a5bc03e6c935a217f5563789bb54c (diff)
* fhandler_disk_file.cc (fhandler_disk_file::fstat): Always call fstat_by_name
if fd is not opened to allow fstat_by_name to properly set errno. * fhandler.cc (binmode): Default to binmode when mode is not known.
Diffstat (limited to 'winsup')
-rw-r--r--winsup/cygwin/ChangeLog10
-rw-r--r--winsup/cygwin/fhandler.cc2
-rw-r--r--winsup/cygwin/fhandler_disk_file.cc6
3 files changed, 14 insertions, 4 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index f525be6c1..f3ccf013e 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,9 @@
+2002-05-30 Christopher Faylor <cgf@redhat.com>
+
+ * fhandler_disk_file.cc (fhandler_disk_file::fstat): Always call
+ fstat_by_name if fd is not opened to allow fstat_by_name to properly
+ set errno.
+
2002-05-30 Corinna Vinschen <corinna@vinschen.de>
* autoload.cc: Replace autoload statments for ZwXXX by NtXXX.
@@ -19,6 +25,10 @@
2002-05-29 Christopher Faylor <cgf@redhat.com>
+ * fhandler.cc (binmode): Default to binmode when mode is not known.
+
+2002-05-29 Christopher Faylor <cgf@redhat.com>
+
* include/sys/cygwin.h (EXTERNAL_PINFO_VERSION): Reinstate.
* external.cc (fillout_pinfo): Use it.
diff --git a/winsup/cygwin/fhandler.cc b/winsup/cygwin/fhandler.cc
index e9af8b4f6..756a74804 100644
--- a/winsup/cygwin/fhandler.cc
+++ b/winsup/cygwin/fhandler.cc
@@ -434,7 +434,7 @@ fhandler_base::open (path_conv *pc, int flags, mode_t mode)
else if (fmode & O_TEXT)
bin = O_TEXT;
else if (get_device () == FH_DISK)
- bin = get_w_binary () || get_r_binary ();
+ bin = get_w_binary () || get_r_binary () || O_BINARY;
else
bin = (binmode == O_BINARY) || get_w_binary () || get_r_binary ();
diff --git a/winsup/cygwin/fhandler_disk_file.cc b/winsup/cygwin/fhandler_disk_file.cc
index c4474f184..5c266ee0b 100644
--- a/winsup/cygwin/fhandler_disk_file.cc
+++ b/winsup/cygwin/fhandler_disk_file.cc
@@ -166,13 +166,13 @@ fhandler_disk_file::fstat (struct __stat64 *buf, path_conv *pc)
}
}
- if (oret)
+ if (!oret)
+ res = fstat_by_name (buf, pc);
+ else
{
res = fstat_by_handle (buf, pc);
close ();
}
- else if (pc->exists ())
- res = fstat_by_name (buf, pc);
return res;
}