/*========================================================================= 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. =========================================================================*/ #ifndef cmUtilitySourceCommand_h #define cmUtilitySourceCommand_h #include "cmCommand.h" /** \class cmUtilitySourceCommand * \brief A command to setup a cache entry with the location of a third-party * utility's source. * * cmUtilitySourceCommand is used when a third-party utility's source is * included in the project's source tree. It specifies the location of * the executable's source, and any files that may be needed to confirm the * identity of the source. */ class cmUtilitySourceCommand : public cmCommand { public: /** * This is a virtual constructor for the command. */ virtual cmCommand* Clone() { return new cmUtilitySourceCommand; } /** * This is called when the command is first encountered in * the CMakeLists.txt file. */ virtual bool InitialPass(std::vector<std::string> const& args); /** * This determines if the command gets propagated down * to makefiles located in subdirectories. */ virtual bool IsInherited() { return true; } /** * The name of the command as specified in CMakeList.txt. */ virtual const char* GetName() { return "UTILITY_SOURCE";} /** * Succinct documentation. */ virtual const char* GetTerseDocumentation() { return "Specify the source tree of a third-party utility."; } /** * More documentation. */ virtual const char* GetFullDocumentation() { return " UTILITY_SOURCE(cache_entry executable_name\n" " path_to_source [file1 file2 ...])\n" "When a third-party utility's source is included in the distribution, " "this command specifies its location and name. The cache entry will " "not be set unless the path_to_source and all listed files exist. It " "is assumed that the source tree of the utility will have been built " "before it is needed."; } cmTypeMacro(cmUtilitySourceCommand, cmCommand); }; #endif