From fd02aa84dc5e5b96e44e1f93b4f57b206e6180b2 Mon Sep 17 00:00:00 2001 From: Francois Pichet Date: Mon, 20 Sep 2010 04:03:07 +0000 Subject: [PATCH] Fix the "unable to rename temporary" lit test failing on Windows. rename is now copy + delete on Windows. Problem to be revisited for a permanent and clean solution. llvm-svn: 114320 --- llvm/lib/System/Win32/Path.inc | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/llvm/lib/System/Win32/Path.inc b/llvm/lib/System/Win32/Path.inc index 4a6dbd3ddf29..64e7025fc9bf 100644 --- a/llvm/lib/System/Win32/Path.inc +++ b/llvm/lib/System/Win32/Path.inc @@ -745,12 +745,19 @@ bool Path::getMagicNumber(std::string& Magic, unsigned len) const { return true; } +// Implements renamePathOnDisk as a CopyFile + eraseFromDisk on Windows. +// Using MoveFileEx was causing mysterious ACCESS_DENIED error when used +// within a multithreaded lit/python context. +// FIXME: put back MoveFileEx when the source of the problem is resolved. bool Path::renamePathOnDisk(const Path& newName, std::string* ErrMsg) { - if (!MoveFileEx(path.c_str(), newName.c_str(), MOVEFILE_REPLACE_EXISTING)) - return MakeErrMsg(ErrMsg, "Can't move '" + path + "' to '" + newName.path - + "': "); - return false; + if (*this == newName) + return false; + + if (CopyFile(newName, *this, ErrMsg)) + return true; + + return eraseFromDisk(true, ErrMsg); } bool