diff options
Diffstat (limited to 'Source/cmTryCompileCommand.cxx')
-rw-r--r-- | Source/cmTryCompileCommand.cxx | 83 |
1 files changed, 76 insertions, 7 deletions
diff --git a/Source/cmTryCompileCommand.cxx b/Source/cmTryCompileCommand.cxx index e044d24..e3d47ee 100644 --- a/Source/cmTryCompileCommand.cxx +++ b/Source/cmTryCompileCommand.cxx @@ -22,7 +22,8 @@ #include <cmsys/Directory.hxx> int cmTryCompileCommand::CoreTryCompileCode( - cmMakefile *mf, std::vector<std::string> const& argv, bool clean) + cmMakefile *mf, std::vector<std::string> const& argv, bool clean, + const char* cmakeCommand, std::string& outputFile) { // which signature were we called with ? bool srcFileSignature = false; @@ -257,11 +258,18 @@ int cmTryCompileCommand::CoreTryCompileCode( } // if They specified clean then we clean up what we can - if (srcFileSignature && clean) - { - if(!mf->GetCMakeInstance()->GetDebugTryCompile()) - { - cmTryCompileCommand::CleanupFiles(binaryDirectory); + if (srcFileSignature) + { + std::string errorMessage; + outputFile = cmTryCompileCommand::GetOutputFile(mf, binaryDirectory, + targetName, cmakeCommand, + errorMessage); + if (clean) + { + if(!mf->GetCMakeInstance()->GetDebugTryCompile()) + { + cmTryCompileCommand::CleanupFiles(binaryDirectory); + } } } return res; @@ -275,7 +283,9 @@ bool cmTryCompileCommand::InitialPass(std::vector<std::string> const& argv) return false; } - cmTryCompileCommand::CoreTryCompileCode(this->Makefile,argv,true); + std::string dummy; + cmTryCompileCommand::CoreTryCompileCode(this->Makefile,argv, true, + this->GetName(), dummy); return true; } @@ -330,3 +340,62 @@ void cmTryCompileCommand::CleanupFiles(const char* binDir) } } } + +const char* cmTryCompileCommand::GetOutputFile(cmMakefile* mf, + const char* binaryDirectory, + const char* targetName, + const char* cmakeCommand, + std::string& errorMessage) +{ + errorMessage = ""; + std::string outputFile = "/"; + outputFile += targetName; + outputFile += mf->GetSafeDefinition("CMAKE_EXECUTABLE_SUFFIX"); + + // a list of directories where to search for the compilation result + // at first directly in the binary dir + std::vector<std::string> searchDirs; + searchDirs.push_back(""); + + const char* config = mf->GetDefinition("CMAKE_TRY_COMPILE_CONFIGURATION"); + // if a config was specified try that first + if (config && config[0]) + { + std::string tmp = "/"; + tmp += config; + searchDirs.push_back(tmp); + } + searchDirs.push_back("/Debug"); + searchDirs.push_back("/Development"); + + for(std::vector<std::string>::const_iterator it = searchDirs.begin(); + it != searchDirs.end(); + ++it) + { + std::string command = binaryDirectory; + command += *it; + command += outputFile; + if(cmSystemTools::FileExists(command.c_str())) + { + outputFile = cmSystemTools::CollapseFullPath(command.c_str()); + return outputFile.c_str(); + } + } + + cmOStringStream emsg; + emsg << "Unable to find executable for " << cmakeCommand << ": tried \""; + for (unsigned int i = 0; i < searchDirs.size(); ++i) + { + emsg << binaryDirectory << searchDirs[i] << outputFile; + if (i < searchDirs.size() - 1) + { + emsg << "\" and \""; + } + else + { + emsg << "\"."; + } + } + errorMessage = emsg.str(); + return ""; +} |