cmQTWrapUICommand.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*=========================================================================
  2. Program: CMake - Cross-Platform Makefile Generator
  3. Module: $RCSfile$
  4. Language: C++
  5. Date: $Date$
  6. Version: $Revision$
  7. Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
  8. See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
  9. This software is distributed WITHOUT ANY WARRANTY; without even
  10. the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  11. PURPOSE. See the above copyright notices for more information.
  12. =========================================================================*/
  13. #ifndef cmQTWrapUICommand_h
  14. #define cmQTWrapUICommand_h
  15. #include "cmStandardIncludes.h"
  16. #include "cmCommand.h"
  17. /** \class cmQTWrapUICommand
  18. * \brief Create .h and .cxx files rules for QT user interfaces files
  19. *
  20. * cmQTWrapUICommand is used to create wrappers for QT classes into normal C++
  21. */
  22. class cmQTWrapUICommand : public cmCommand
  23. {
  24. public:
  25. /**
  26. * This is a virtual constructor for the command.
  27. */
  28. virtual cmCommand* Clone()
  29. {
  30. return new cmQTWrapUICommand;
  31. }
  32. /**
  33. * This is called when the command is first encountered in
  34. * the CMakeLists.txt file.
  35. */
  36. virtual bool InitialPass(std::vector<std::string> const& args);
  37. /**
  38. * This is called at the end after all the information
  39. * specified by the command is accumulated. Most commands do
  40. * not implement this method. At this point, reading and
  41. * writing to the cache can be done.
  42. */
  43. virtual void FinalPass();
  44. /**
  45. * The name of the command as specified in CMakeList.txt.
  46. */
  47. virtual const char* GetName() { return "QT_WRAP_UI";}
  48. /**
  49. * Succinct documentation.
  50. */
  51. virtual const char* GetTerseDocumentation()
  52. {
  53. return "Create QT user interfaces Wrappers.";
  54. }
  55. /**
  56. * More documentation.
  57. */
  58. virtual const char* GetFullDocumentation()
  59. {
  60. return
  61. "QT_WRAP_UI(resultingLibraryName HeadersDestName SourcesDestName "
  62. "SourceLists ...)\n"
  63. "Produce .h and .cxx files for all the .ui file listed "
  64. "in the SourceLists.\n"
  65. "The .h files will be added to the library using the HeadersDestName\n"
  66. "source list.\n"
  67. "The .cxx files will be added to the library using the SourcesDestName\n"
  68. "source list.";
  69. }
  70. private:
  71. /**
  72. * List of produced files.
  73. */
  74. std::vector<cmSourceFile> m_WrapSourcesClasses;
  75. std::vector<cmSourceFile> m_WrapHeadersClasses;
  76. std::vector<cmSourceFile> m_WrapMocClasses;
  77. /**
  78. * List of header files that pprovide the source for m_WrapClasses.
  79. */
  80. std::vector<std::string> m_WrapUserInterface;
  81. std::string m_LibraryName;
  82. std::string m_HeaderList;
  83. std::string m_SourceList;
  84. };
  85. #endif