aboutsummaryrefslogtreecommitdiff
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
parenta1a486d70ebcc47a686ff5846875eacad0940e41 (diff)
downloadglibc-e095db0bc6c53a0b7ac3d915c5feb7678049dc33.tar
glibc-e095db0bc6c53a0b7ac3d915c5feb7678049dc33.tar.gz
glibc-e095db0bc6c53a0b7ac3d915c5feb7678049dc33.tar.bz2
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.
-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);