Blame SOURCES/cpio-2.11-retain-symlink-times.patch

b9e021
From 7a4094d382e74aaed0a0b8356dc24d64952852f9 Mon Sep 17 00:00:00 2001
b9e021
From: Pavel Raiskup <praiskup@redhat.com>
b9e021
Date: Fri, 3 Jul 2020 12:32:58 +0200
b9e021
Subject: [PATCH] Extract: retain times for symlinks
b9e021
b9e021
Original report by Pat Riehecky at
b9e021
https://bugzilla.redhat.com/1486364
b9e021
b9e021
* src/copyin.c (copyin_device): Don't check for retain_time_flag
b9e021
global, it's done by set_file_times.
b9e021
(copyin_link): Call set_file_times to restore symlink times.
b9e021
* src/util.c (set_perms): Don't check for retain_time_flag global,
b9e021
done by set_file_times call.
b9e021
(set_file_times): Do nothing if retain_time_flag global is false.
b9e021
* src/copypass.c (process_copy_pass): Call set_file_times for
b9e021
symlinks.
b9e021
---
b9e021
 src/copyin.c   | 5 ++---
b9e021
 src/copypass.c | 2 ++
b9e021
 src/util.c     | 6 ++++--
b9e021
 3 files changed, 8 insertions(+), 5 deletions(-)
b9e021
b9e021
diff --git a/src/copyin.c b/src/copyin.c
b9e021
index 183b5b5..267ed4b 100644
b9e021
--- a/src/copyin.c
b9e021
+++ b/src/copyin.c
b9e021
@@ -639,9 +639,7 @@ copyin_device (struct cpio_file_stat* file_hdr)
b9e021
   /* chown may have turned off some permissions we wanted. */
b9e021
   if (chmod (file_hdr->c_name, file_hdr->c_mode) < 0)
b9e021
     chmod_error_details (file_hdr->c_name, file_hdr->c_mode);
b9e021
-  if (retain_time_flag)
b9e021
-    set_file_times (-1, file_hdr->c_name, file_hdr->c_mtime,
b9e021
-		    file_hdr->c_mtime);
b9e021
+  set_file_times (-1, file_hdr->c_name, file_hdr->c_mtime, file_hdr->c_mtime);
b9e021
 }
b9e021
 
b9e021
 static void
b9e021
@@ -692,6 +690,7 @@ copyin_link (struct cpio_file_stat *file_hdr, int in_file_des)
b9e021
   	  && errno != EPERM)
b9e021
 	chown_error_details (file_hdr->c_name, uid, gid);
b9e021
     }
b9e021
+  set_file_times (-1, file_hdr->c_name, file_hdr->c_mtime, file_hdr->c_mtime);
b9e021
   free (link_name);
b9e021
 }
b9e021
 
b9e021
diff --git a/src/copypass.c b/src/copypass.c
b9e021
index c5a9899..b4e7169 100644
b9e021
--- a/src/copypass.c
b9e021
+++ b/src/copypass.c
b9e021
@@ -317,6 +317,8 @@ process_copy_pass ()
b9e021
 		  && errno != EPERM)
b9e021
 	        chown_error_details (output_name.ds_string, uid, gid);
b9e021
             }
b9e021
+		  set_file_times (-1, output_name.ds_string,
b9e021
+        				  in_file_stat.st_atime, in_file_stat.st_mtime);
b9e021
 	  free (link_name);
b9e021
 	}
b9e021
 #endif
b9e021
diff --git a/src/util.c b/src/util.c
b9e021
index 6ff6032..11f9c30 100644
b9e021
--- a/src/util.c
b9e021
+++ b/src/util.c
b9e021
@@ -1389,7 +1389,6 @@ set_perms (int fd, struct cpio_file_stat *header)
b9e021
        we have to refer to it using name+ instead of name.  */
b9e021
     file_hdr->c_name [cdf_char] = '+';
b9e021
 #endif
b9e021
-  if (retain_time_flag)
b9e021
     set_file_times (fd, header->c_name, header->c_mtime, header->c_mtime);
b9e021
 }
b9e021
 
b9e021
@@ -1398,6 +1397,8 @@ set_file_times (int fd,
b9e021
 		const char *name, unsigned long atime, unsigned long mtime)
b9e021
 {
b9e021
   struct timespec ts[2];
b9e021
+  if (!retain_time_flag)
b9e021
+    return;
b9e021
   
b9e021
   memset (&ts, 0, sizeof ts);
b9e021
 
b9e021
@@ -1406,7 +1407,8 @@ set_file_times (int fd,
b9e021
 
b9e021
   /* Silently ignore EROFS because reading the file won't have upset its 
b9e021
      timestamp if it's on a read-only filesystem. */
b9e021
-  if (fdutimens (fd, name, ts) < 0 && errno != EROFS)
b9e021
+  if ((fd >= 0 ? fdutimens (fd, NULL, ts) : lutimens (name, ts)) < 0
b9e021
+      && errno != EROFS)
b9e021
     utime_error (name);
b9e021
 }
b9e021
 
b9e021
-- 
b9e021
2.24.1
b9e021