diff options
| author | Reid Spencer <rspencer@reidspencer.com> | 2004-09-28 23:58:03 +0000 |
|---|---|---|
| committer | Reid Spencer <rspencer@reidspencer.com> | 2004-09-28 23:58:03 +0000 |
| commit | 70b683585345137a8275a8036e8d5d6f40c521b2 (patch) | |
| tree | 8f32cfb76037a1324740cb88a3cacb31496f26e3 /llvm/lib/System | |
| parent | 364cce404a87fcf60626696457f8dffca23f0172 (diff) | |
| download | bcm5719-llvm-70b683585345137a8275a8036e8d5d6f40c521b2.tar.gz bcm5719-llvm-70b683585345137a8275a8036e8d5d6f40c521b2.zip | |
Use llvm::sys::Path to destroy the file.
Patch contributed by Jeff Cohen. Thanks Jeff!
llvm-svn: 16564
Diffstat (limited to 'llvm/lib/System')
| -rw-r--r-- | llvm/lib/System/Win32/Signals.cpp | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/llvm/lib/System/Win32/Signals.cpp b/llvm/lib/System/Win32/Signals.cpp index 692a0476b1f..908ae84c4b7 100644 --- a/llvm/lib/System/Win32/Signals.cpp +++ b/llvm/lib/System/Win32/Signals.cpp @@ -13,6 +13,7 @@ #include "Win32.h" #include <llvm/System/Signals.h> +#include <stdio.h> #include <vector> #ifdef __MINGW_H @@ -29,7 +30,7 @@ static LONG WINAPI LLVMUnhandledExceptionFilter(LPEXCEPTION_POINTERS ep); static BOOL WINAPI LLVMConsoleCtrlHandler(DWORD dwCtrlType); -static std::vector<std::string> *FilesToRemove = NULL; +static std::vector<llvm::sys::Path> *FilesToRemove = NULL; static std::vector<llvm::sys::Path> *DirectoriesToRemove = NULL; static bool RegisteredUnhandledExceptionFilter = false; static bool CleanupExecuted = false; @@ -78,9 +79,9 @@ void sys::RemoveFileOnSignal(const std::string &Filename) { throw std::string("Process terminating -- cannot register for removal"); if (FilesToRemove == NULL) - FilesToRemove = new std::vector<std::string>; + FilesToRemove = new std::vector<sys::Path>; - FilesToRemove->push_back(Filename); + FilesToRemove->push_back(sys::Path(Filename)); LeaveCriticalSection(&CriticalSection); } @@ -123,7 +124,7 @@ static void Cleanup() { if (FilesToRemove != NULL) while (!FilesToRemove->empty()) { try { - std::remove(FilesToRemove->back().c_str()); + FilesToRemove->back().destroy_file(); } catch (...) { } FilesToRemove->pop_back(); |

