From 8066d1a2839e6eb0b1b5cddde033311ec887a486 Mon Sep 17 00:00:00 2001 From: Andreas Schwab Date: Thu, 27 May 1999 03:16:15 +0000 Subject: [PATCH] * objcopy.c (copy_archive): Preserve dates of archive members if requested. --- binutils/ChangeLog | 3 +++ binutils/objcopy.c | 13 +++++++++++++ 2 files changed, 16 insertions(+) diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 746baf1f671..f5491d361df 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,5 +1,8 @@ Thu May 27 11:58:33 1999 Andreas Schwab + * objcopy.c (copy_archive): Preserve dates of archive members if + requested. + * readelf.c (dump_relocations): Always print the addend on RELA systems even if there is no symbol. (process_program_headers): Reset dynamic_size before looping diff --git a/binutils/objcopy.c b/binutils/objcopy.c index 5fd77775d70..5e6d6836f43 100644 --- a/binutils/objcopy.c +++ b/binutils/objcopy.c @@ -962,6 +962,16 @@ copy_archive (ibfd, obfd, output_target) (char *) NULL); bfd *output_bfd = bfd_openw (output_name, output_target); bfd *last_element; + struct stat buf; + int stat_status = 0; + + if (preserve_dates) + { + stat_status = bfd_stat_arch_elt (this_element, &buf); + if (stat_status != 0) + non_fatal (_("internal stat error on %s"), + bfd_get_filename (this_element)); + } l = (struct name_list *) xmalloc (sizeof (struct name_list)); l->name = output_name; @@ -984,6 +994,9 @@ copy_archive (ibfd, obfd, output_target) status = 1; } + if (preserve_dates && stat_status == 0) + set_times (output_name, &buf); + /* Open the newly output file and attach to our list. */ output_bfd = bfd_openr (output_name, output_target); -- 2.30.2