зеркало из https://github.com/microsoft/clang-1.git
Don't test isRegularFile before calling eraseFromDisk, since
eraseFromDisk does the same check. This avoids a stat call in the common case. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@117744 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
1e592cba6b
Коммит
978e3a274a
|
@ -101,21 +101,15 @@ bool Compilation::CleanupFileList(const ArgStringList &Files,
|
|||
llvm::sys::Path P(*it);
|
||||
std::string Error;
|
||||
|
||||
if (!P.isRegularFile()) {
|
||||
// If we have a special file in our list, i.e. /dev/null
|
||||
// then don't call eraseFromDisk() and just continue.
|
||||
continue;
|
||||
}
|
||||
|
||||
if (P.eraseFromDisk(false, &Error)) {
|
||||
// Failure is only failure if the file doesn't exist. There is a
|
||||
// race condition here due to the limited interface of
|
||||
// llvm::sys::Path, we want to know if the removal gave E_NOENT.
|
||||
// Failure is only failure if the file exists and is "regular". There is
|
||||
// a race condition here due to the limited interface of
|
||||
// llvm::sys::Path, we want to know if the removal gave ENOENT.
|
||||
|
||||
// FIXME: Grumble, P.exists() is broken. PR3837.
|
||||
struct stat buf;
|
||||
if (::stat(P.c_str(), &buf) == 0
|
||||
|| errno != ENOENT) {
|
||||
if (::stat(P.c_str(), &buf) == 0 ? S_ISREG(buf.st_mode) :
|
||||
(errno != ENOENT)) {
|
||||
if (IssueErrors)
|
||||
getDriver().Diag(clang::diag::err_drv_unable_to_remove_file)
|
||||
<< Error;
|
||||
|
|
Загрузка…
Ссылка в новой задаче