summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorKen Martin <ken.martin@kitware.com>2008-05-30 13:14:25 (GMT)
committerKen Martin <ken.martin@kitware.com>2008-05-30 13:14:25 (GMT)
commit5020a1f4a012fb83781c3c28811e55a0ba68b50b (patch)
treef646e30340db1f0402b93b3145e7a08daff92677 /Source
parentda273b10264ecc7ad5880adfb292d21e6512831c (diff)
downloadCMake-5020a1f4a012fb83781c3c28811e55a0ba68b50b.zip
CMake-5020a1f4a012fb83781c3c28811e55a0ba68b50b.tar.gz
CMake-5020a1f4a012fb83781c3c28811e55a0ba68b50b.tar.bz2
ENH: make tes test finding logic also try full paths as relative paths because some folks have been doing that and 2.4 handled it
Diffstat (limited to 'Source')
-rw-r--r--Source/CTest/cmCTestTestHandler.cxx19
1 files changed, 15 insertions, 4 deletions
diff --git a/Source/CTest/cmCTestTestHandler.cxx b/Source/CTest/cmCTestTestHandler.cxx
index 9a6792e..7a3086e 100644
--- a/Source/CTest/cmCTestTestHandler.cxx
+++ b/Source/CTest/cmCTestTestHandler.cxx
@@ -1165,7 +1165,7 @@ std::string cmCTestTestHandler::FindTheExecutable(const char *exe)
failedPaths);
}
-// add additional configuraitons to the search path
+// add additional configurations to the search path
void cmCTestTestHandler
::AddConfigurations(cmCTest *ctest,
std::vector<std::string> &attempted,
@@ -1175,7 +1175,8 @@ void cmCTestTestHandler
{
std::string tempPath;
- if (filepath.size())
+ if (filepath.size() &&
+ filepath[filepath.size()-1] != '/')
{
filepath += "/";
}
@@ -1259,6 +1260,16 @@ std::string cmCTestTestHandler
attemptedConfigs,
filepath,filename);
+ // even if a fullpath was specified also try it relative to the current directory
+ if (filepath.size() && filepath[0] == '/')
+ {
+ std::string localfilepath = filepath.substr(1,filepath.size()-1);
+ cmCTestTestHandler::AddConfigurations(ctest, attempted,
+ attemptedConfigs,
+ localfilepath,filename);
+ }
+
+
// if extraPaths are provided and we were not passed a full path, try them,
// try any extra paths
if (filepath.size() == 0)
@@ -1274,8 +1285,8 @@ std::string cmCTestTestHandler
filepathExtra,
filenameExtra);
}
- }
-
+ }
+
// store the final location in fullPath
std::string fullPath;