ENH: mark some vars as advanced (and resort the list)
[cmake.git] / Source / cmRemoveCommand.h
blob54fbe3da246552a7026b4c1bfed36857cb1ba116
1 /*=========================================================================
3 Program: Insight Segmentation & Registration Toolkit
4 Module: $RCSfile: cmRemoveCommand.h,v $
5 Language: C++
6 Date: $Date: 2002-04-22 15:50:43 $
7 Version: $Revision: 1.1 $
9 Copyright (c) 2002 Insight Consortium. All rights reserved.
10 See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
12 This software is distributed WITHOUT ANY WARRANTY; without even
13 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 PURPOSE. See the above copyright notices for more information.
16 =========================================================================*/
17 #ifndef cmRemoveCommand_h
18 #define cmRemoveCommand_h
20 #include "cmStandardIncludes.h"
21 #include "cmCommand.h"
23 /** \class cmRemoveCommand
24 * \brief Set a CMAKE variable
26 * cmRemoveCommand sets a variable to a value with expansion.
28 class cmRemoveCommand : public cmCommand
30 public:
31 /**
32 * This is a virtual constructor for the command.
34 virtual cmCommand* Clone()
36 return new cmRemoveCommand;
39 /**
40 * This is called when the command is first encountered in
41 * the CMakeLists.txt file.
43 virtual bool InitialPass(std::vector<std::string> const& args);
45 /**
46 * This determines if the command gets propagated down
47 * to makefiles located in subdirectories.
49 virtual bool IsInherited() {return true;}
51 /**
52 * The name of the command as specified in CMakeList.txt.
54 virtual const char* GetName() {return "REMOVE";}
56 /**
57 * Succinct documentation.
59 virtual const char* GetTerseDocumentation()
61 return "Remove a value from a CMAKE variable";
64 /**
65 * More documentation.
67 virtual const char* GetFullDocumentation()
69 return
70 "REMOVE(VAR VALUE VALUE ...)\n"
71 "Removes VALUE from the CMAke variable VAR. "
72 "This is typically used to remove entries from a vector "
73 "(e.g. semicolon separated list). VALUE is expanded. ";
76 cmTypeMacro(cmRemoveCommand, cmCommand);
81 #endif