mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-26 05:32:25 +00:00
On error, close the temporary file descriptor.
With this change llvm-ar can remove the temporary file on windows too. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186423 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
21508bf853
commit
95779b65cf
9
test/Object/archive-error-tmp.txt
Normal file
9
test/Object/archive-error-tmp.txt
Normal file
@ -0,0 +1,9 @@
|
||||
REQUIRES: shell
|
||||
|
||||
Test that no temporary file is left behind on error.
|
||||
|
||||
RUN: rm -rf %t
|
||||
RUN: mkdir %t
|
||||
RUN: not llvm-ar rc %t/foo.a .
|
||||
RUN: rmdir %t
|
||||
|
@ -41,10 +41,13 @@ using namespace llvm;
|
||||
static StringRef ToolName;
|
||||
|
||||
static const char *TemporaryOutput;
|
||||
static int TmpArchiveFD = -1;
|
||||
|
||||
// fail - Show the error message and exit.
|
||||
LLVM_ATTRIBUTE_NORETURN static void fail(Twine Error) {
|
||||
outs() << ToolName << ": " << Error << ".\n";
|
||||
if (TmpArchiveFD != -1)
|
||||
close(TmpArchiveFD);
|
||||
if (TemporaryOutput)
|
||||
sys::fs::remove(TemporaryOutput);
|
||||
exit(1);
|
||||
@ -526,7 +529,6 @@ static void printWithSpacePadding(raw_ostream &OS, T Data, unsigned Size) {
|
||||
|
||||
static void performWriteOperation(ArchiveOperation Operation,
|
||||
object::Archive *OldArchive) {
|
||||
int TmpArchiveFD;
|
||||
SmallString<128> TmpArchive;
|
||||
failIfError(sys::fs::createUniqueFile(ArchiveName + ".temp-archive-%%%%%%%.a",
|
||||
TmpArchiveFD, TmpArchive));
|
||||
|
Loading…
Reference in New Issue
Block a user