summaryrefslogtreecommitdiffstats
path: root/Source/cmaketest.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmaketest.cxx')
-rw-r--r--Source/cmaketest.cxx46
1 files changed, 29 insertions, 17 deletions
diff --git a/Source/cmaketest.cxx b/Source/cmaketest.cxx
index 571e2f7..b3c250c 100644
--- a/Source/cmaketest.cxx
+++ b/Source/cmaketest.cxx
@@ -40,6 +40,7 @@ int main (int argc, char *argv[])
cmSystemTools::ChangeDirectory(binaryDirectory);
cmake cm;
std::vector<std::string> args;
+ // make sure the same generator is used
// use this program as the cmake to be run, it should not
// be run that way but the cmake object requires a vailid path
std::string cmakeCommand = CMAKE_COMMAND;
@@ -53,6 +54,10 @@ int main (int argc, char *argv[])
}
args.push_back(cmakeCommand.c_str());
args.push_back(sourceDirectory);
+ std::string generator = "-G";
+ generator += CMAKE_GENERATOR;
+ args.push_back(generator);
+
if (cm.Generate(args) != 0)
{
std::cerr << "Error: cmake execution failed\n";
@@ -63,26 +68,33 @@ int main (int argc, char *argv[])
cmListFileCache::GetInstance()->ClearCache();
// now build the test
std::string makeCommand = MAKEPROGRAM;
-#if defined(_WIN32) && !defined(__CYGWIN__) && !defined(__BORLANDC__)
- // if there are spaces in the makeCommand, assume a full path
- // and convert it to a path with no spaces in it as the
- // RunCommand does not like spaces
- if(makeCommand.find(' ') != std::string::npos)
- {
- char *buffer = new char[makeCommand.size()+1];
- if(GetShortPathName(makeCommand.c_str(), buffer,
- makeCommand.size()+1) != 0)
+ std::string lowerCaseCommand = makeCommand;
+ cmSystemTools::LowerCase(lowerCaseCommand);
+ // if msdev is the make program then do the following
+ if(lowerCaseCommand.find("msdev") != std::string::npos)
+ {
+ // if there are spaces in the makeCommand, assume a full path
+ // and convert it to a path with no spaces in it as the
+ // RunCommand does not like spaces
+ if(makeCommand.find(' ') != std::string::npos)
{
- makeCommand = buffer;
- delete [] buffer;
+ char *buffer = new char[makeCommand.size()+1];
+ if(GetShortPathName(makeCommand.c_str(), buffer,
+ makeCommand.size()+1) != 0)
+ {
+ makeCommand = buffer;
+ delete [] buffer;
+ }
}
+ makeCommand += " ";
+ makeCommand += executableName;
+ makeCommand += ".dsw /MAKE \"ALL_BUILD - Debug\" /REBUILD";
+ }
+ else
+ {
+ // assume a make sytle program
+ makeCommand += " all";
}
- makeCommand += " ";
- makeCommand += executableName;
- makeCommand += ".dsw /MAKE \"ALL_BUILD - Debug\" /REBUILD";
-#else
- makeCommand += " all";
-#endif
if (!cmSystemTools::RunCommand(makeCommand.c_str(), output))
{
std::cerr << "Error: " << makeCommand.c_str() << " execution failed\n";