diff options
author | Christopher Faylor <me@cgf.cx> | 2002-05-31 00:15:22 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2002-05-31 00:15:22 +0000 |
commit | 5d8c7a56c287079c59491f3dee8e33e05cefdf45 (patch) | |
tree | 7d09f9c81e5466f437202c5a6bc273c3939499bb | |
parent | 53e05aecc10a5bc03e6c935a217f5563789bb54c (diff) | |
download | cygnal-5d8c7a56c287079c59491f3dee8e33e05cefdf45.tar.gz cygnal-5d8c7a56c287079c59491f3dee8e33e05cefdf45.tar.bz2 cygnal-5d8c7a56c287079c59491f3dee8e33e05cefdf45.zip |
* 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.
-rw-r--r-- | winsup/cygwin/ChangeLog | 10 | ||||
-rw-r--r-- | winsup/cygwin/fhandler.cc | 2 | ||||
-rw-r--r-- | winsup/cygwin/fhandler_disk_file.cc | 6 |
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; } |