+2021-04-15 Alan Modra <amodra@gmail.com>
+
+ PR 27456
+ * rename.c (smart_rename): When TO and FROM are equal, just set
+ file timestamp.
+ * objcopy.c (strip_main, copy_main): Always call smart_rename.
+
2021-04-14 H.J. Lu <hongjiu.lu@intel.com>
PR binutils/27708
output_target, NULL);
if (status == 0)
{
- if (output_file != tmpname)
- status = smart_rename (tmpname,
- output_file ? output_file : argv[i],
- copyfd, &statbuf, preserve_dates) != 0;
+ const char *oname = output_file ? output_file : argv[i];
+ status = smart_rename (tmpname, oname, copyfd,
+ &statbuf, preserve_dates) != 0;
if (status == 0)
status = hold_status;
}
output_target, input_arch);
if (status == 0)
{
- if (tmpname != output_filename)
- status = smart_rename (tmpname, input_filename, copyfd,
- &statbuf, preserve_dates) != 0;
+ const char *oname = output_filename ? output_filename : input_filename;
+ status = smart_rename (tmpname, oname, copyfd,
+ &statbuf, preserve_dates) != 0;
}
else
{
smart_rename (const char *from, const char *to, int fromfd,
struct stat *target_stat, bool preserve_dates)
{
- int ret;
+ int ret = 0;
- ret = simple_copy (fromfd, to, target_stat);
- if (ret != 0)
- non_fatal (_("unable to copy file '%s'; reason: %s"),
- to, strerror (errno));
+ if (to != from)
+ {
+ ret = simple_copy (fromfd, to, target_stat);
+ if (ret != 0)
+ non_fatal (_("unable to copy file '%s'; reason: %s"),
+ to, strerror (errno));
+ unlink (from);
+ }
if (preserve_dates)
set_times (to, target_stat);
- unlink (from);
return ret;
}