about summary refs log tree commit diff
path: root/hurd
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2020-03-29 19:42:55 +0200
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2020-03-29 19:42:55 +0200
commite095db0bc6c53a0b7ac3d915c5feb7678049dc33 (patch)
tree632d55f51a54ecdbdd6ac35165362e1487f27653 /hurd
parenta1a486d70ebcc47a686ff5846875eacad0940e41 (diff)
downloadglibc-e095db0bc6c53a0b7ac3d915c5feb7678049dc33.tar.gz
glibc-e095db0bc6c53a0b7ac3d915c5feb7678049dc33.tar.xz
glibc-e095db0bc6c53a0b7ac3d915c5feb7678049dc33.zip
hurd: Make O_TRUNC update mtime/ctime
* hurd/lookup-retry.c (__hurd_file_name_lookup_retry): Call
__file_utimens after __file_set_size.
Diffstat (limited to 'hurd')
-rw-r--r--hurd/lookup-retry.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/hurd/lookup-retry.c b/hurd/lookup-retry.c
index c90eda808d..6d8b05e4e6 100644
--- a/hurd/lookup-retry.c
+++ b/hurd/lookup-retry.c
@@ -178,8 +178,17 @@ __hurd_file_name_lookup_retry (error_t (*use_init_port)
 	      /* We got a successful translation.  Now apply any open-time
 		 action flags we were passed.  */
 
-	      if (!err && (flags & O_TRUNC)) /* Asked to truncate the file.  */
-		err = __file_set_size (*result, 0);
+	      if (!err && (flags & O_TRUNC))
+		{
+		  /* Asked to truncate the file.  */
+		  err = __file_set_size (*result, 0);
+		  if (!err)
+		    {
+		      struct timespec atime = { 0, UTIME_OMIT };
+		      struct timespec mtime = { 0, UTIME_NOW };
+		      __file_utimens (*result, atime, mtime);
+		    }
+		}
 
 	      if (err)
 		__mach_port_deallocate (__mach_task_self (), *result);