Implement functionality suggested from code review: getStatusInfo should
authorReid Spencer <rspencer@reidspencer.com>
Sun, 14 Nov 2004 23:30:38 +0000 (23:30 +0000)
committerReid Spencer <rspencer@reidspencer.com>
Sun, 14 Nov 2004 23:30:38 +0000 (23:30 +0000)
returnn false if the file doesn't exist rather than throw ane exception.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17809 91177308-0d34-0410-b5e6-96231b3b80d8

lib/System/Unix/Path.cpp
lib/System/Unix/Path.inc

index c6dbf87ed0b90ded1438697a9823748459bcfd1a..d2ba0f903591080acd594eb53998a2a5c2e3573f 100644 (file)
@@ -239,8 +239,10 @@ Path::getLast() const {
   return path.substr(pos+1);
 }
 
-void
+bool
 Path::getStatusInfo(StatusInfo& info) {
+  if (!isFile() || !readable())
+    return false;
   struct stat buf;
   if (0 != stat(path.c_str(), &buf)) {
     ThrowErrno(std::string("Can't get status: ")+path);
@@ -253,6 +255,7 @@ Path::getStatusInfo(StatusInfo& info) {
   info.isDir = S_ISDIR(buf.st_mode);
   if (info.isDir && path[path.length()-1] != '/')
     path += '/';
+  return true;
 }
 
 bool
index c6dbf87ed0b90ded1438697a9823748459bcfd1a..d2ba0f903591080acd594eb53998a2a5c2e3573f 100644 (file)
@@ -239,8 +239,10 @@ Path::getLast() const {
   return path.substr(pos+1);
 }
 
-void
+bool
 Path::getStatusInfo(StatusInfo& info) {
+  if (!isFile() || !readable())
+    return false;
   struct stat buf;
   if (0 != stat(path.c_str(), &buf)) {
     ThrowErrno(std::string("Can't get status: ")+path);
@@ -253,6 +255,7 @@ Path::getStatusInfo(StatusInfo& info) {
   info.isDir = S_ISDIR(buf.st_mode);
   if (info.isDir && path[path.length()-1] != '/')
     path += '/';
+  return true;
 }
 
 bool