diff options
author | Ken Martin <ken.martin@kitware.com> | 2007-12-03 17:44:42 (GMT) |
---|---|---|
committer | Ken Martin <ken.martin@kitware.com> | 2007-12-03 17:44:42 (GMT) |
commit | 951444165f4c18c83efe47f8e86656df9c690983 (patch) | |
tree | 97989bfe2f1fc2e710152d64cfa3cfa55a5731d6 /Source/cmRaiseScopeCommand.h | |
parent | 50bdabde07e4339c8ce0118a128d53eb1f9c14a0 (diff) | |
download | CMake-951444165f4c18c83efe47f8e86656df9c690983.zip CMake-951444165f4c18c83efe47f8e86656df9c690983.tar.gz CMake-951444165f4c18c83efe47f8e86656df9c690983.tar.bz2 |
ENH: add functions and raise scope to cmake
Diffstat (limited to 'Source/cmRaiseScopeCommand.h')
-rw-r--r-- | Source/cmRaiseScopeCommand.h | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/Source/cmRaiseScopeCommand.h b/Source/cmRaiseScopeCommand.h new file mode 100644 index 0000000..51d4f1f --- /dev/null +++ b/Source/cmRaiseScopeCommand.h @@ -0,0 +1,85 @@ +/*========================================================================= + + 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 cmRaiseScopeCommand_h +#define cmRaiseScopeCommand_h + +#include "cmCommand.h" + +/** \class cmRaiseScopeCommand + * \brief Raise the Scope a CMAKE variable one level up + * + * cmRaiseScopeCommand pushes the current state of a variable into + * the scope above the current scope. + */ +class cmRaiseScopeCommand : public cmCommand +{ +public: + /** + * This is a virtual constructor for the command. + */ + virtual cmCommand* Clone() + { + return new cmRaiseScopeCommand; + } + + /** + * This is called when the command is first encountered in + * the CMakeLists.txt file. + */ + virtual bool InitialPass(std::vector<std::string> const& args); + + /** + * The name of the command as specified in CMakeList.txt. + */ + virtual const char* GetName() {return "raise_scope";} + + /** + * Succinct documentation. + */ + virtual const char* GetTerseDocumentation() + { + return "Raise the scope of the variables listed."; + } + + /** + * More documentation. + */ + virtual const char* GetFullDocumentation() + { + return + " raise_scope(VAR VAR2 VAR...)\n" + "Pushes the current state of a variable into the scope above the " + "current scope. Each new directory or function creates a new scope. " + "This command will push the current state of a variable into the " + "parent directory or calling function (whichever is applicable to " + "the case at hand)"; + } + + /** + * This determines if the command is invoked when in script mode. + * mark_as_advanced() will have no effect in script mode, but this will + * make many of the modules usable in cmake/ctest scripts, (among them + * FindUnixMake.cmake used by the CTEST_BUILD command. + */ + virtual bool IsScriptable() { return true; } + + cmTypeMacro(cmRaiseScopeCommand, cmCommand); +}; + + + +#endif |