summaryrefslogtreecommitdiffstats
path: root/Source/cmake.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmake.cxx')
-rw-r--r--Source/cmake.cxx93
1 files changed, 93 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();
+}
+