| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- /*=========================================================================
- Program: CMake - Cross-Platform Makefile Generator
- Module: $RCSfile$
- Language: C++
- Date: $Date$
- Version: $Revision$
- Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
- See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
- This software is distributed WITHOUT ANY WARRANTY; without even
- the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
- PURPOSE. See the above copyright notices for more information.
- =========================================================================*/
- #include "cmCTestConfigureHandler.h"
- #include "cmCTest.h"
- #include "cmGeneratedFileStream.h"
- #include "cmake.h"
- #include <cmsys/Process.h>
- //----------------------------------------------------------------------
- cmCTestConfigureHandler::cmCTestConfigureHandler()
- {
- }
- //----------------------------------------------------------------------
- void cmCTestConfigureHandler::Initialize()
- {
- }
- //----------------------------------------------------------------------
- //clearly it would be nice if this were broken up into a few smaller
- //functions and commented...
- int cmCTestConfigureHandler::ProcessHandler()
- {
- cmCTestLog(m_CTest, HANDLER_OUTPUT, "Configure project" << std::endl);
- std::string cCommand = m_CTest->GetCTestConfiguration("ConfigureCommand");
- if ( cCommand.size() == 0 )
- {
- cmCTestLog(m_CTest, ERROR_MESSAGE, "Cannot find ConfigureCommand key in the DartConfiguration.tcl"
- << std::endl);
- return -1;
- }
- std::string buildDirectory = m_CTest->GetCTestConfiguration("BuildDirectory");
- if ( buildDirectory.size() == 0 )
- {
- cmCTestLog(m_CTest, ERROR_MESSAGE, "Cannot find BuildDirectory key in the DartConfiguration.tcl" << std::endl);
- return -1;
- }
- double elapsed_time_start = cmSystemTools::GetTime();
- std::string output;
- int retVal = 0;
- int res = 0;
- if ( !m_CTest->GetShowOnly() )
- {
- cmGeneratedFileStream os;
- if ( !m_CTest->OpenOutputFile(m_CTest->GetCurrentTag(), "Configure.xml", os, true) )
- {
- cmCTestLog(m_CTest, ERROR_MESSAGE, "Cannot open configure file" << std::endl);
- return 1;
- }
- std::string start_time = m_CTest->CurrentTime();
- cmGeneratedFileStream ofs;
- m_CTest->OpenOutputFile("Temporary", "LastConfigure.log", ofs);
- cmCTestLog(m_CTest, HANDLER_VERBOSE_OUTPUT, "Configure with command: " << cCommand.c_str() << std::endl);
- res = m_CTest->RunMakeCommand(cCommand.c_str(), &output,
- &retVal, buildDirectory.c_str(),
- 0, ofs);
- if ( ofs )
- {
- ofs.close();
- }
-
- if ( os )
- {
- m_CTest->StartXML(os);
- os << "<Configure>\n"
- << "\t<StartDateTime>" << start_time << "</StartDateTime>" << std::endl;
- if ( res == cmsysProcess_State_Exited && retVal )
- {
- os << retVal;
- }
- os << "<ConfigureCommand>" << cCommand.c_str() << "</ConfigureCommand>" << std::endl;
- cmCTestLog(m_CTest, DEBUG, "End" << std::endl);
- os << "<Log>" << cmCTest::MakeXMLSafe(output) << "</Log>" << std::endl;
- std::string end_time = m_CTest->CurrentTime();
- os << "\t<ConfigureStatus>" << retVal << "</ConfigureStatus>\n"
- << "\t<EndDateTime>" << end_time << "</EndDateTime>\n"
- << "<ElapsedMinutes>"
- << static_cast<int>(
- (cmSystemTools::GetTime() - elapsed_time_start)/6)/10.0
- << "</ElapsedMinutes>"
- << "</Configure>" << std::endl;
- m_CTest->EndXML(os);
- }
- }
- else
- {
- cmCTestLog(m_CTest, DEBUG, "Configure with command: " << cCommand << std::endl);
- }
- if (! res || retVal )
- {
- cmCTestLog(m_CTest, ERROR_MESSAGE, "Error(s) when updating the project" << std::endl);
- return -1;
- }
- return 0;
- }
|