summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorJohn Biddiscombe <jbiddiscombe@skippingmouse.co.uk>2001-09-11 23:58:22 (GMT)
committerJohn Biddiscombe <jbiddiscombe@skippingmouse.co.uk>2001-09-11 23:58:22 (GMT)
commitea40b86683c58325b8086650f2c7aac0a21ac02d (patch)
tree7fdadc9355591308992b9a2f6307ee7c449fd7b7 /Source
parentfaafcdddbf83e3efc96eb04fd80cce4c8514a5fa (diff)
downloadCMake-ea40b86683c58325b8086650f2c7aac0a21ac02d.zip
CMake-ea40b86683c58325b8086650f2c7aac0a21ac02d.tar.gz
CMake-ea40b86683c58325b8086650f2c7aac0a21ac02d.tar.bz2
ENH: Add a findfile routine (as opposed to find executable or library) which doesn't
add any extensions - Borland make needs full paths to certain dependencies otherwise linking doesn't work properly (dependencies aren't checked)
Diffstat (limited to 'Source')
-rw-r--r--Source/cmSystemTools.cxx35
-rw-r--r--Source/cmSystemTools.h4
2 files changed, 35 insertions, 4 deletions
diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx
index 245b084..795208d 100644
--- a/Source/cmSystemTools.cxx
+++ b/Source/cmSystemTools.cxx
@@ -923,8 +923,35 @@ std::string cmSystemTools::TemporaryFileName()
risk of setting rights with 0666 */
return tempnam(0, "cmake");
}
-
+/**
+ * Find the file the given name. Searches the given path and then
+ * the system search path. Returns the full path to the file if it is
+ * found. Otherwise, the empty string is returned.
+ */
+std::string cmSystemTools::FindFile(const char* name,
+ const std::vector<std::string>& userPaths)
+{
+ // Add the system search path to our path.
+ std::vector<std::string> path = userPaths;
+ cmSystemTools::GetPath(path);
+
+ std::string tryPath;
+ for(std::vector<std::string>::const_iterator p = path.begin();
+ p != path.end(); ++p)
+ {
+ tryPath = *p;
+ tryPath += "/";
+ tryPath += name;
+ if(cmSystemTools::FileExists(tryPath.c_str()) &&
+ !cmSystemTools::FileIsDirectory(tryPath.c_str()))
+ {
+ return cmSystemTools::CollapseFullPath(tryPath.c_str());
+ }
+ }
+ // Couldn't find the file.
+ return "";
+}
/**
* Find the executable with the given name. Searches the given path and then
@@ -947,11 +974,11 @@ std::string cmSystemTools::FindProgram(const char* name,
{
return cmSystemTools::CollapseFullPath(tryPath.c_str());
}
-
+
// Add the system search path to our path.
std::vector<std::string> path = userPaths;
cmSystemTools::GetPath(path);
-
+
for(std::vector<std::string>::const_iterator p = path.begin();
p != path.end(); ++p)
{
@@ -970,7 +997,7 @@ std::string cmSystemTools::FindProgram(const char* name,
return cmSystemTools::CollapseFullPath(tryPath.c_str());
}
}
-
+
// Couldn't find the program.
return "";
}
diff --git a/Source/cmSystemTools.h b/Source/cmSystemTools.h
index f6b4356..c7c44af 100644
--- a/Source/cmSystemTools.h
+++ b/Source/cmSystemTools.h
@@ -205,6 +205,10 @@ public:
*/
static bool IsOff(const char* val);
+ ///! Find a file in the system PATH, with optional extra paths.
+ static std::string FindFile(const char* name,
+ const std::vector<std::string>& path= std::vector<std::string>());
+
///! Find an executable in the system PATH, with optional extra paths.
static std::string FindProgram(const char* name,
const std::vector<std::string>& path= std::vector<std::string>());