aboutsummaryrefslogtreecommitdiffstats
path: root/lib/System/Win32
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-07-28 22:29:50 +0000
committerChris Lattner <sabre@nondot.org>2006-07-28 22:29:50 +0000
commit0c33231eff17edbdabdb186e1fae718cf94b58b2 (patch)
treeb7b5e08357f3a04f92267bbbc0ee9d8915a82900 /lib/System/Win32
parent65a392ebeae214ccb25f4d5ec856688e4e690e0d (diff)
downloadexternal_llvm-0c33231eff17edbdabdb186e1fae718cf94b58b2.zip
external_llvm-0c33231eff17edbdabdb186e1fae718cf94b58b2.tar.gz
external_llvm-0c33231eff17edbdabdb186e1fae718cf94b58b2.tar.bz2
Modify Path::eraseFromDisk to not throw an exception.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29400 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/System/Win32')
-rw-r--r--lib/System/Win32/Path.inc21
1 files changed, 10 insertions, 11 deletions
diff --git a/lib/System/Win32/Path.inc b/lib/System/Win32/Path.inc
index f33654e..15c686d 100644
--- a/lib/System/Win32/Path.inc
+++ b/lib/System/Win32/Path.inc
@@ -571,19 +571,19 @@ Path::createFileOnDisk() {
}
bool
-Path::eraseFromDisk(bool remove_contents) const {
+Path::eraseFromDisk(bool remove_contents, std::string *ErrStr) const {
if (isFile()) {
DWORD attr = GetFileAttributes(path.c_str());
// If it doesn't exist, we're done.
if (attr == INVALID_FILE_ATTRIBUTES)
- return true;
+ return false;
// Read-only files cannot be deleted on Windows. Must remove the read-only
// attribute first.
if (attr & FILE_ATTRIBUTE_READONLY) {
if (!SetFileAttributes(path.c_str(), attr & ~FILE_ATTRIBUTE_READONLY))
- ThrowError(path + ": Can't destroy file: ");
+ return GetError(path + ": Can't destroy file: ", ErrStr);
}
if (!DeleteFile(path.c_str()))
@@ -592,7 +592,7 @@ Path::eraseFromDisk(bool remove_contents) const {
} else if (isDirectory()) {
// If it doesn't exist, we're done.
if (!exists())
- return true;
+ return false;
char *pathname = reinterpret_cast<char *>(_alloca(path.length()+3));
int lastchar = path.length() - 1 ;
@@ -629,7 +629,7 @@ Path::eraseFromDisk(bool remove_contents) const {
FindClose(h);
if (err != ERROR_NO_MORE_FILES) {
SetLastError(err);
- ThrowError(path + ": Can't read directory: ");
+ return GetError(path + ": Can't read directory: ", ErrStr);
}
for (std::vector<Path>::iterator I = list.begin(); I != list.end();
@@ -639,17 +639,18 @@ Path::eraseFromDisk(bool remove_contents) const {
}
} else {
if (GetLastError() != ERROR_FILE_NOT_FOUND)
- ThrowError(path + ": Can't read directory: ");
+ return GetError(path + ": Can't read directory: ", ErrStr);
}
}
pathname[lastchar] = 0;
if (!RemoveDirectory(pathname))
- ThrowError(std::string(pathname) + ": Can't destroy directory: ");
- return true;
+ return GetError(std::string(pathname) + ": Can't destroy directory: ",
+ ErrStr);
+ return false;
} else {
// It appears the path doesn't exist.
- return false;
+ return true;
}
}
@@ -789,5 +790,3 @@ Path::createTemporaryFileOnDisk(bool reuse_current) {
}
}
-
-