cmGetDirectoryPropertyCommand.h 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*============================================================================
  2. CMake - Cross Platform Makefile Generator
  3. Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
  4. Distributed under the OSI-approved BSD License (the "License");
  5. see accompanying file Copyright.txt for details.
  6. This software is distributed WITHOUT ANY WARRANTY; without even the
  7. implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  8. See the License for more information.
  9. ============================================================================*/
  10. #ifndef cmGetDirectoryPropertyCommand_h
  11. #define cmGetDirectoryPropertyCommand_h
  12. #include "cmCommand.h"
  13. class cmGetDirectoryPropertyCommand : public cmCommand
  14. {
  15. public:
  16. virtual cmCommand* Clone()
  17. {
  18. return new cmGetDirectoryPropertyCommand;
  19. }
  20. /**
  21. * This is called when the command is first encountered in
  22. * the input file.
  23. */
  24. virtual bool InitialPass(std::vector<std::string> const& args,
  25. cmExecutionStatus &status);
  26. /**
  27. * This determines if the command is invoked when in script mode.
  28. */
  29. virtual bool IsScriptable() { return true; }
  30. /**
  31. * The name of the command as specified in CMakeList.txt.
  32. */
  33. virtual const char* GetName() { return "get_directory_property";}
  34. /**
  35. * Succinct documentation.
  36. */
  37. virtual const char* GetTerseDocumentation()
  38. {
  39. return "Get a property of DIRECTORY scope.";
  40. }
  41. /**
  42. * Longer documentation.
  43. */
  44. virtual const char* GetFullDocumentation()
  45. {
  46. return
  47. " get_directory_property(<variable> [DIRECTORY <dir>] <prop-name>)\n"
  48. "Store a property of directory scope in the named variable. "
  49. "If the property is not defined the empty-string is returned. "
  50. "The DIRECTORY argument specifies another directory from which "
  51. "to retrieve the property value. "
  52. "The specified directory must have already been traversed by "
  53. "CMake."
  54. "\n"
  55. " get_directory_property(<variable> [DIRECTORY <dir>]\n"
  56. " DEFINITION <var-name>)\n"
  57. "Get a variable definition from a directory. "
  58. "This form is useful to get a variable definition from another "
  59. "directory."
  60. ;
  61. }
  62. cmTypeMacro(cmGetDirectoryPropertyCommand, cmCommand);
  63. };
  64. #endif