summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmake.cxx93
-rw-r--r--Source/cmake.h8
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;