summaryrefslogtreecommitdiff
path: root/bfd/cache.c
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@airs.com>2000-04-03 19:19:11 +0000
committerIan Lance Taylor <ian@airs.com>2000-04-03 19:19:11 +0000
commit9909905c4981ed493a329023dafa0f5e278c3abc (patch)
tree8e603cedb8055bbea0cd4504fcbef1a2ab220d33 /bfd/cache.c
parent8352dcff7f7eab46ae99220ec4a32676e52e0076 (diff)
downloadbinutils-redhat-9909905c4981ed493a329023dafa0f5e278c3abc.tar.gz
2000-04-03 H.J. Lu <hjl@gnu.org>
* cache.c (bfd_open_file): Unlink the output file only if it has none zero size.
Diffstat (limited to 'bfd/cache.c')
-rw-r--r--bfd/cache.c23
1 files changed, 19 insertions, 4 deletions
diff --git a/bfd/cache.c b/bfd/cache.c
index b28de4bc4b..ad3140e1ed 100644
--- a/bfd/cache.c
+++ b/bfd/cache.c
@@ -285,10 +285,25 @@ bfd_open_file (abfd)
}
else
{
- /* Create the file. Unlink it first, for the convenience of
- operating systems which worry about overwriting running
- binaries. */
- unlink (abfd->filename);
+ /* Create the file.
+
+ Some operating systems won't let us overwrite a running
+ binary. For them, we want to unlink the file first.
+
+ However, gcc 2.95 will create temporary files using
+ O_EXCL and tight permissions to prevent other users from
+ substituting other .o files during the compilation. gcc
+ will then tell the assembler to use the newly created
+ file as an output file. If we unlink the file here, we
+ open a brief window when another user could still
+ substitute a file.
+
+ So we unlink the output file if and only if it has
+ non-zero size. */
+ struct stat s;
+
+ if (stat (abfd->filename, &s) == 0 && s.st_size != 0)
+ unlink (abfd->filename);
abfd->iostream = (PTR) fopen (abfd->filename, FOPEN_WB);
abfd->opened_once = true;
}