/*============================================================================ CMake - Cross Platform Makefile Generator Copyright 2000-2009 Kitware, Inc., Insight Software Consortium Distributed under the OSI-approved BSD License (the "License"); see accompanying file Copyright.txt for details. 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 cmCTestCoverageCommand_h #define cmCTestCoverageCommand_h #include "cmCTestHandlerCommand.h" /** \class cmCTestCoverage * \brief Run a ctest script * * cmCTestCoverageCommand defineds the command to test the project. */ class cmCTestCoverageCommand : public cmCTestHandlerCommand { public: cmCTestCoverageCommand(); /** * This is a virtual constructor for the command. */ virtual cmCommand* Clone() { cmCTestCoverageCommand* ni = new cmCTestCoverageCommand; ni->CTest = this->CTest; ni->CTestScriptHandler = this->CTestScriptHandler; return ni; } /** * The name of the command as specified in CMakeList.txt. */ virtual const char* GetName() { return "ctest_coverage";} /** * Succinct documentation. */ virtual const char* GetTerseDocumentation() { return "Collect coverage tool results."; } /** * More documentation. */ virtual const char* GetFullDocumentation() { return " ctest_coverage([BUILD build_dir] [RETURN_VALUE res] [APPEND]\n" " [LABELS label1 [label2 [...]]])\n" "Perform the coverage of the given build directory and stores results " "in Coverage.xml. The second argument is a variable that will hold " "value." "\n" "The LABELS option filters the coverage report to include only " "source files labeled with at least one of the labels specified." "\n" CTEST_COMMAND_APPEND_OPTION_DOCS; } cmTypeMacro(cmCTestCoverageCommand, cmCTestHandlerCommand); protected: cmCTestGenericHandler* InitializeHandler(); virtual bool CheckArgumentKeyword(std::string const& arg); virtual bool CheckArgumentValue(std::string const& arg); enum { ArgumentDoingLabels = Superclass::ArgumentDoingLast1, ArgumentDoingLast2 }; bool LabelsMentioned; std::set<cmStdString> Labels; }; #endif