diff options
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmake.cxx | 93 | ||||
-rw-r--r-- | Source/cmake.h | 8 |
2 files changed, 101 insertions, 0 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx index c730548..d8733c1 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -1880,3 +1880,96 @@ void cmake::TruncateOutputLog(const char* fname) } } +inline std::string removeQuotes(const std::string& s) +{ + if(s[0] == '\"' && s[s.size()-1] == '\"') + { + return s.substr(1, s.size()-2); + } + return s; +} + +const char* cmake::GetCTestCommand() +{ + if ( !m_CTestCommand.empty() ) + { + return m_CTestCommand.c_str(); + } + + cmMakefile* mf = this->GetGlobalGenerator()->GetLocalGenerator(0)->GetMakefile(); + m_CTestCommand = mf->GetRequiredDefinition("CMAKE_COMMAND"); + m_CTestCommand = removeQuotes(m_CTestCommand); + m_CTestCommand = cmSystemTools::GetFilenamePath(m_CTestCommand.c_str()); + m_CTestCommand += "/"; + m_CTestCommand += "ctest"; + m_CTestCommand += cmSystemTools::GetExecutableExtension(); + if(!cmSystemTools::FileExists(m_CTestCommand.c_str())) + { + m_CTestCommand = mf->GetRequiredDefinition("CMAKE_COMMAND"); + m_CTestCommand = cmSystemTools::GetFilenamePath(m_CTestCommand.c_str()); + m_CTestCommand += "/Debug/"; + m_CTestCommand += "ctest"; + m_CTestCommand += cmSystemTools::GetExecutableExtension(); + } + if(!cmSystemTools::FileExists(m_CTestCommand.c_str())) + { + m_CTestCommand = mf->GetRequiredDefinition("CMAKE_COMMAND"); + m_CTestCommand = cmSystemTools::GetFilenamePath(m_CTestCommand.c_str()); + m_CTestCommand += "/Release/"; + m_CTestCommand += "ctest"; + m_CTestCommand += cmSystemTools::GetExecutableExtension(); + } + if ( m_CTestCommand.empty() ) + { + cmSystemTools::Error("Cannot find the CTest executable"); + m_CTestCommand = "CTEST-COMMAND-NOT-FOUND"; + } + return m_CTestCommand.c_str(); +} + +const char* cmake::GetCPackCommand() +{ + if ( !m_CPackCommand.empty() ) + { + return m_CPackCommand.c_str(); + } + + cmMakefile* mf = this->GetGlobalGenerator()->GetLocalGenerator(0)->GetMakefile(); + +#ifdef CMAKE_BUILD_WITH_CMAKE + m_CPackCommand = mf->GetRequiredDefinition("CMAKE_COMMAND"); + m_CPackCommand = removeQuotes(m_CPackCommand); + m_CPackCommand = cmSystemTools::GetFilenamePath(m_CPackCommand.c_str()); + m_CPackCommand += "/"; + m_CPackCommand += "cpack"; + m_CPackCommand += cmSystemTools::GetExecutableExtension(); + if(!cmSystemTools::FileExists(m_CPackCommand.c_str())) + { + m_CPackCommand = mf->GetRequiredDefinition("CMAKE_COMMAND"); + m_CPackCommand = cmSystemTools::GetFilenamePath(m_CPackCommand.c_str()); + m_CPackCommand += "/Debug/"; + m_CPackCommand += "cpack"; + m_CPackCommand += cmSystemTools::GetExecutableExtension(); + } + if(!cmSystemTools::FileExists(m_CPackCommand.c_str())) + { + m_CPackCommand = mf->GetRequiredDefinition("CMAKE_COMMAND"); + m_CPackCommand = cmSystemTools::GetFilenamePath(m_CPackCommand.c_str()); + m_CPackCommand += "/Release/"; + m_CPackCommand += "cpack"; + m_CPackCommand += cmSystemTools::GetExecutableExtension(); + } + if (!cmSystemTools::FileExists(m_CPackCommand.c_str())) + { + cmSystemTools::Error("Cannot find the CPack executable"); + m_CPackCommand = "CPACK-COMMAND-NOT-FOUND"; + } +#else + // Only for bootstrap + m_CPackCommand += mf->GetSafeDefinition("EXECUTABLE_OUTPUT_PATH"); + m_CPackCommand += "/cpack"; + m_CPackCommand += cmSystemTools::GetExecutableExtension(); +#endif + return m_CPackCommand.c_str(); +} + diff --git a/Source/cmake.h b/Source/cmake.h index 47a62b4..a8c8c57 100644 --- a/Source/cmake.h +++ b/Source/cmake.h @@ -268,6 +268,12 @@ class cmake */ cmFileTimeComparison* GetFileComparison() { return m_FileComparison; } + /** + * Get the path to ctest + */ + const char* GetCTestCommand(); + const char* GetCPackCommand(); + protected: typedef cmGlobalGenerator* (*CreateGeneratorFunctionType)(); typedef std::map<cmStdString, CreateGeneratorFunctionType> RegisteredGeneratorsMap; @@ -317,6 +323,8 @@ private: std::string m_CXXEnvironment; std::string m_CCEnvironment; std::string m_CheckBuildSystem; + std::string m_CTestCommand; + std::string m_CPackCommand; bool m_ClearBuildSystem; bool m_DebugTryCompile; cmFileTimeComparison* m_FileComparison; |