CMake/Source/CTest/cmCTestStartCommand.h

93 lines
2.6 KiB
C
Raw Normal View History

2009-10-02 01:21:28 +04:00
/*============================================================================
CMake - Cross Platform Makefile Generator
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
2009-10-02 01:21:28 +04:00
Distributed under the OSI-approved BSD License (the "License");
see accompanying file Copyright.txt for details.
2009-10-02 01:21:28 +04:00
This software is distributed WITHOUT ANY WARRANTY; without even the
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the License for more information.
============================================================================*/
#ifndef cmCTestStartCommand_h
#define cmCTestStartCommand_h
#include "cmCTestCommand.h"
/** \class cmCTestStart
* \brief Run a ctest script
*
* cmCTestStartCommand defineds the command to start the nightly testing.
*/
class cmCTestStartCommand : public cmCTestCommand
{
public:
2010-01-29 00:48:20 +03:00
cmCTestStartCommand();
2006-03-09 19:17:10 +03:00
/**
* This is a virtual constructor for the command.
*/
2006-03-09 19:17:10 +03:00
virtual cmCommand* Clone()
{
cmCTestStartCommand* ni = new cmCTestStartCommand;
2006-03-10 23:03:09 +03:00
ni->CTest = this->CTest;
ni->CTestScriptHandler = this->CTestScriptHandler;
2010-01-29 00:48:20 +03:00
ni->CreateNewTag = this->CreateNewTag;
return ni;
}
/**
* This is called when the command is first encountered in
* the CMakeLists.txt file.
*/
virtual bool InitialPass(std::vector<std::string> const& args,
cmExecutionStatus &status);
2010-01-29 00:48:20 +03:00
/**
* Will this invocation of ctest_start create a new TAG file?
*/
bool ShouldCreateNewTag()
{
return this->CreateNewTag;
}
/**
* The name of the command as specified in CMakeList.txt.
*/
virtual const char* GetName() { return "ctest_start";}
/**
* Succinct documentation.
*/
2006-03-09 19:17:10 +03:00
virtual const char* GetTerseDocumentation()
{
return "Starts the testing for a given model";
}
2006-03-09 19:17:10 +03:00
/**
* More documentation.
*/
virtual const char* GetFullDocumentation()
{
return
2010-01-29 00:48:20 +03:00
" ctest_start(Model [TRACK <track>] [APPEND] [source [binary]])\n"
2006-03-09 19:17:10 +03:00
"Starts the testing for a given model. The command should be called "
"after the binary directory is initialized. If the 'source' and "
"'binary' directory are not specified, it reads the "
"CTEST_SOURCE_DIRECTORY and CTEST_BINARY_DIRECTORY. If the track is "
2010-01-29 00:48:20 +03:00
"specified, the submissions will go to the specified track. "
"If APPEND is used, the existing TAG is used rather than "
"creating a new one based on the current time stamp.";
}
cmTypeMacro(cmCTestStartCommand, cmCTestCommand);
2010-01-29 00:48:20 +03:00
private:
bool InitialCheckout(std::ostream& ofs, std::string const& sourceDir);
bool CreateNewTag;
};
#endif