From: corinna Date: Thu, 17 Feb 2005 12:41:47 +0000 (+0000) Subject: * fhandler_disk_file.cc (fhandler_disk_file::fstat): Set st_ctime if X-Git-Tag: pre_wait_sig_exit~3045 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=6e95e72a0e60464336aeb6e3b3515f3c9813e476;p=pf3gnuchains%2Fpf3gnuchains4x.git * fhandler_disk_file.cc (fhandler_disk_file::fstat): Set st_ctime if has_changed flag is set. (fhandler_disk_file::touch_ctime): Reset has_changed flag on success. --- diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index f04afaffc0..178cf81d96 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,5 +1,11 @@ 2005-02-17 Corinna Vinschen + * fhandler_disk_file.cc (fhandler_disk_file::fstat): Set st_ctime if + has_changed flag is set. + (fhandler_disk_file::touch_ctime): Reset has_changed flag on success. + +2005-02-17 Corinna Vinschen + * times.cc (utimes): Open files with FILE_WRITE_ATTRIBUTES first, if that fails, try opeing with GENERIC_WRITE. Fix comments. diff --git a/winsup/cygwin/fhandler_disk_file.cc b/winsup/cygwin/fhandler_disk_file.cc index 129e9ce6bd..8644e89643 100644 --- a/winsup/cygwin/fhandler_disk_file.cc +++ b/winsup/cygwin/fhandler_disk_file.cc @@ -374,6 +374,8 @@ fhandler_base::fstat_helper (struct __stat64 *buf, int __stdcall fhandler_disk_file::fstat (struct __stat64 *buf) { + if (has_changed ()) + touch_ctime (); return fstat_fs (buf); } @@ -387,6 +389,8 @@ fhandler_disk_file::touch_ctime (void) SystemTimeToFileTime (&st, &ft); if (!SetFileTime (get_io_handle (), &ft, NULL, NULL)) debug_printf ("SetFileTime (%s) failed, %E", get_win32_name ()); + else + has_changed (false); } int __stdcall