summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2006-03-11 16:52:57 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2006-03-11 16:52:57 (GMT)
commit08bb4d52ba2d56381e2471136ef1e5e5845bf18c (patch)
treec66a34fb581bbd2b3876c3d3474b1c321078c381
parent6420337317f2e11bbbbc703728fad93f8749a094 (diff)
downloadCMake-08bb4d52ba2d56381e2471136ef1e5e5845bf18c.zip
CMake-08bb4d52ba2d56381e2471136ef1e5e5845bf18c.tar.gz
CMake-08bb4d52ba2d56381e2471136ef1e5e5845bf18c.tar.bz2
ENH: try to clean up the search for programs
-rw-r--r--Source/kwsys/SystemTools.cxx96
1 files changed, 50 insertions, 46 deletions
diff --git a/Source/kwsys/SystemTools.cxx b/Source/kwsys/SystemTools.cxx
index bb81a19..dfcbcd8 100644
--- a/Source/kwsys/SystemTools.cxx
+++ b/Source/kwsys/SystemTools.cxx
@@ -1914,55 +1914,71 @@ kwsys_stl::string SystemTools
* found. Otherwise, the empty string is returned.
*/
kwsys_stl::string SystemTools::FindProgram(
- const char* name,
+ const char* nameIn,
const kwsys_stl::vector<kwsys_stl::string>& userPaths,
bool no_system_path)
{
- if(!name)
+ if(!nameIn)
{
return "";
}
- kwsys_stl::string ext = SystemTools::GetExecutableExtension();
- if(ext.size())
+ kwsys_stl::string name = nameIn;
+ bool hasExtension = false;
+ // check to see if the name already has a .xxx at
+ // the end of it
+ if(name.size() > 3 && name[name.size()-4] == '.')
{
- unsigned int len = strlen(name);
- if(len > ext.size())
+ hasExtension = true;
+ }
+ kwsys_stl::vector<kwsys_stl::string> extensions;
+#if defined (_WIN32) || defined(__CYGWIN__) | defined(__MINGW32__)
+ // on windows try .com then .exe
+ if(!hasExtension)
+ {
+ extensions.push_back(".com");
+ extensions.push_back(".exe");
+ }
+#endif
+ kwsys_stl::string tryPath;
+ // first try the name as it was given (adding extensions
+ // if needed.)
+ if(extensions.size())
+ {
+ for(kwsys_stl::vector<kwsys_stl::string>::iterator i =
+ extensions.begin(); i != extensions.end(); ++i)
{
- if(strcmp(name+(len-ext.size()), ext.c_str()) == 0)
+ tryPath = name;
+ tryPath += *i;
+ if(SystemTools::FileExists(tryPath.c_str()) &&
+ !SystemTools::FileIsDirectory(tryPath.c_str()))
{
- ext = ""; // name already has Executable extension
+ return SystemTools::CollapseFullPath(tryPath.c_str());
}
}
}
- // See if the executable exists as written.
- if(SystemTools::FileExists(name) &&
- !SystemTools::FileIsDirectory(name))
- {
- return SystemTools::CollapseFullPath(name);
- }
- if(ext.size())
+ else
{
- kwsys_stl::string tryPath = name;
- tryPath += ext;
+ tryPath = name;
if(SystemTools::FileExists(tryPath.c_str()) &&
!SystemTools::FileIsDirectory(tryPath.c_str()))
{
return SystemTools::CollapseFullPath(tryPath.c_str());
}
}
+ // now construct the path
kwsys_stl::vector<kwsys_stl::string> path;
// Add the system search path to our path.
if (!no_system_path)
{
SystemTools::GetPath(path);
}
-
// now add the additional paths
- for(kwsys_stl::vector<kwsys_stl::string>::const_iterator i = userPaths.begin();
- i != userPaths.end(); ++i)
+ for(kwsys_stl::vector<kwsys_stl::string>::const_iterator i =
+ userPaths.begin(); i != userPaths.end(); ++i)
{
path.push_back(*i);
}
+ // Try each path
for(kwsys_stl::vector<kwsys_stl::string>::iterator p = path.begin();
p != path.end(); ++p)
{
@@ -1970,38 +1986,27 @@ kwsys_stl::string SystemTools::FindProgram(
// Remove double quotes from the path on windows
SystemTools::ReplaceString(*p, "\"", "");
#endif
- kwsys_stl::string tryPath = *p;
- tryPath += "/";
- tryPath += name;
- if(SystemTools::FileExists(tryPath.c_str()) &&
- !SystemTools::FileIsDirectory(tryPath.c_str()))
- {
- return SystemTools::CollapseFullPath(tryPath.c_str());
- }
-#ifdef _WIN32
- // on windows try .com before .exe
- if(ext.size() == 0)
+ if(extensions.size())
{
- SystemTools::ReplaceString(tryPath, ".exe", ".com");
- SystemTools::ReplaceString(tryPath, ".EXE", ".com");
+ for(kwsys_stl::vector<kwsys_stl::string>::iterator ext
+ = extensions.begin(); ext != extensions.end(); ++ext)
+ {
+ tryPath = *p;
+ tryPath += "/";
+ tryPath += name;
+ tryPath += *ext;
+ if(SystemTools::FileExists(tryPath.c_str()) &&
+ !SystemTools::FileIsDirectory(tryPath.c_str()))
+ {
+ return SystemTools::CollapseFullPath(tryPath.c_str());
+ }
+ }
}
else
{
- tryPath += ".com";
- }
- if(SystemTools::FileExists(tryPath.c_str()) &&
- !SystemTools::FileIsDirectory(tryPath.c_str()))
- {
- return SystemTools::CollapseFullPath(tryPath.c_str());
- }
-#endif
- // now try to add ext if it is different than name
- if(ext.size())
- {
tryPath = *p;
tryPath += "/";
tryPath += name;
- tryPath += ext;
if(SystemTools::FileExists(tryPath.c_str()) &&
!SystemTools::FileIsDirectory(tryPath.c_str()))
{
@@ -2009,7 +2014,6 @@ kwsys_stl::string SystemTools::FindProgram(
}
}
}
-
// Couldn't find the program.
return "";
}