cmLibraryRule.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*=========================================================================
  2. Program: Insight Segmentation & Registration Toolkit
  3. Module: $RCSfile$
  4. Language: C++
  5. Date: $Date$
  6. Version: $Revision$
  7. Copyright (c) 2000 National Library of Medicine
  8. All rights reserved.
  9. See COPYRIGHT.txt for copyright details.
  10. =========================================================================*/
  11. #ifndef cmLibraryRule_h
  12. #define cmLibraryRule_h
  13. #include "cmStandardIncludes.h"
  14. #include "cmRuleMaker.h"
  15. /** \class cmLibraryRule
  16. * \brief Specify a name for a library.
  17. *
  18. * cmLibraryRule is used to specify the name of a library to be
  19. * generated by the build process.
  20. */
  21. class cmLibraryRule : public cmRuleMaker
  22. {
  23. public:
  24. /**
  25. * This is a virtual constructor for the rule.
  26. */
  27. virtual cmRuleMaker* Clone()
  28. {
  29. return new cmLibraryRule;
  30. }
  31. /**
  32. * This is called when the rule is first encountered in
  33. * the CMakeLists.txt file.
  34. */
  35. virtual bool Invoke(std::vector<std::string>& args);
  36. /**
  37. * This is called at the end after all the information
  38. * specified by the rules is accumulated.
  39. */
  40. virtual void FinalPass() { }
  41. /**
  42. * The name of the rule as specified in CMakeList.txt.
  43. */
  44. virtual const char* GetName() { return "LIBRARY";}
  45. /**
  46. * Succinct documentation.
  47. */
  48. virtual const char* TerseDocumentation()
  49. {
  50. return "Set a name for a library.";
  51. }
  52. /**
  53. * More documentation.
  54. */
  55. virtual const char* FullDocumentation()
  56. {
  57. return
  58. "LIBRARY(libraryname)";
  59. }
  60. };
  61. #endif