diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 746baf1f67..f5491d361d 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 5fd77775d7..5e6d6836f4 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);