diff options
Diffstat (limited to 'Source/cmTryRunCommand.cxx')
-rw-r--r-- | Source/cmTryRunCommand.cxx | 154 |
1 files changed, 38 insertions, 116 deletions
diff --git a/Source/cmTryRunCommand.cxx b/Source/cmTryRunCommand.cxx index ab8670c3ea..8179a771e3 100644 --- a/Source/cmTryRunCommand.cxx +++ b/Source/cmTryRunCommand.cxx @@ -71,140 +71,62 @@ bool cmTryRunCommand::InitialPass(std::vector<std::string> const& argv) } } // do the try compile - int res = cmTryCompileCommand::CoreTryCompileCode(this->Makefile, - tryCompile, false); - + std::string fullPath; + int res = cmTryCompileCommand::CoreTryCompileCode(this->Makefile, tryCompile, + false, this->GetName(), fullPath); + // now try running the command if it compiled - std::string binaryDirectory = argv[2]; - binaryDirectory += cmake::GetCMakeFilesDirectory(); - binaryDirectory += "/CMakeTmp"; - if (!res) + if (!res==0) + { + if (fullPath.size() > 0) { int retVal = -1; std::string output; - std::string executableSuffix=this->Makefile->GetDefinition( - "CMAKE_EXECUTABLE_SUFFIX"); - std::string command1 = binaryDirectory; - std::vector<std::string> attemptedPaths; - command1 += "/cmTryCompileExec"; - command1 += executableSuffix; - std::string fullPath; - if(cmSystemTools::FileExists(command1.c_str())) - { - fullPath = cmSystemTools::CollapseFullPath(command1.c_str()); - } - attemptedPaths.push_back(command1); - command1 = binaryDirectory; - // try CMAKE_TRY_COMPILE_CONFIGURATION if it is set - if (fullPath.empty()) + std::string finalCommand = fullPath; + finalCommand = cmSystemTools::ConvertToRunCommandPath(fullPath.c_str()); + if(runArgs.size()) { - const char* config = - this->Makefile->GetDefinition("CMAKE_TRY_COMPILE_CONFIGURATION"); - // if a config was specified try that first - if (config && config[0]) - { - command1 += "/"; - command1 += config; - command1 += "/cmTryCompileExec"; - command1 += executableSuffix; - if(cmSystemTools::FileExists(command1.c_str())) - { - fullPath = cmSystemTools::CollapseFullPath(command1.c_str()); - } - attemptedPaths.push_back(command1); - } + finalCommand += runArgs; } - // try Debug if still not found - if (fullPath.empty()) + int timeout = 0; + bool worked = cmSystemTools::RunSingleCommand(finalCommand.c_str(), + &output, &retVal, + 0, false, timeout); + if(outputVariable.size()) { - command1 = binaryDirectory; - command1 += "/Debug/cmTryCompileExec"; - command1 += executableSuffix; - if(cmSystemTools::FileExists(command1.c_str())) + // if the TryCompileCore saved output in this outputVariable then + // prepend that output to this output + const char* compileOutput + = this->Makefile->GetDefinition(outputVariable.c_str()); + if(compileOutput) { - fullPath = cmSystemTools::CollapseFullPath(command1.c_str()); + output = std::string(compileOutput) + output; } - attemptedPaths.push_back(command1); + this->Makefile->AddDefinition(outputVariable.c_str(), output.c_str()); } - // try Deployment if still not found - if (fullPath.empty()) + // set the run var + char retChar[1000]; + if(worked) { - command1 = binaryDirectory; - command1 += "/Development/cmTryCompileExec"; - command1 += executableSuffix; - if(cmSystemTools::FileExists(command1.c_str())) - { - fullPath = cmSystemTools::CollapseFullPath(command1.c_str()); - } - attemptedPaths.push_back(command1); - } - if (fullPath.empty()) - { - cmOStringStream emsg; - emsg << "Unable to find executable for TRY_RUN: tried \""; - for (i = 0; i < attemptedPaths.size(); ++i) - { - emsg << attemptedPaths[i]; - if (i < attemptedPaths.size() - 1) - { - emsg << "\" and \""; - } - else - { - emsg << "\"."; - } - } - cmSystemTools::Error(emsg.str().c_str()); + sprintf(retChar,"%i",retVal); } - if (fullPath.size() > 1) + else { - std::string finalCommand = fullPath; - finalCommand = cmSystemTools::ConvertToRunCommandPath(fullPath.c_str()); - if(runArgs.size()) - { - finalCommand += runArgs; - } - int timeout = 0; - bool worked = cmSystemTools::RunSingleCommand(finalCommand.c_str(), - &output, &retVal, - 0, false, timeout); - if(outputVariable.size()) - { - // if the TryCompileCore saved output in this outputVariable then - // prepend that output to this output - const char* compileOutput - = this->Makefile->GetDefinition(outputVariable.c_str()); - if(compileOutput) - { - output = std::string(compileOutput) + output; - } - this->Makefile->AddDefinition(outputVariable.c_str(), output.c_str()); - } - // set the run var - char retChar[1000]; - if(worked) - { - sprintf(retChar,"%i",retVal); - } - else - { - strcpy(retChar, "FAILED_TO_RUN"); - } - this->Makefile->AddCacheDefinition(argv[0].c_str(), retChar, - "Result of TRY_RUN", - cmCacheManager::INTERNAL); + strcpy(retChar, "FAILED_TO_RUN"); } + this->Makefile->AddCacheDefinition(argv[0].c_str(), retChar, + "Result of TRY_RUN", + cmCacheManager::INTERNAL); } - - // if we created a directory etc, then cleanup after ourselves - std::string cacheFile = binaryDirectory; - cacheFile += "/CMakeLists.txt"; + } + + // if we created a directory etc, then cleanup after ourselves if(!this->Makefile->GetCMakeInstance()->GetDebugTryCompile()) { + std::string binaryDirectory = argv[2]; + binaryDirectory += cmake::GetCMakeFilesDirectory(); + binaryDirectory += "/CMakeTmp"; cmTryCompileCommand::CleanupFiles(binaryDirectory.c_str()); } return true; } - - - |