cmEnableLanguageCommand.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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 cmEnableLanguageCommand_h
  11. #define cmEnableLanguageCommand_h
  12. #include "cmCommand.h"
  13. /** \class cmEnableLanguageCommand
  14. * \brief Specify the name for this build project.
  15. *
  16. * cmEnableLanguageCommand is used to specify a name for this build project.
  17. * It is defined once per set of CMakeList.txt files (including
  18. * all subdirectories). Currently it just sets the name of the workspace
  19. * file for Microsoft Visual C++
  20. */
  21. class cmEnableLanguageCommand : public cmCommand
  22. {
  23. public:
  24. /**
  25. * This is a virtual constructor for the command.
  26. */
  27. virtual cmCommand* Clone()
  28. {
  29. return new cmEnableLanguageCommand;
  30. }
  31. /**
  32. * This is called when the command is first encountered in
  33. * the CMakeLists.txt file.
  34. */
  35. virtual bool InitialPass(std::vector<std::string> const& args,
  36. cmExecutionStatus &status);
  37. /**
  38. * The name of the command as specified in CMakeList.txt.
  39. */
  40. virtual const char* GetName() const {return "enable_language";}
  41. /**
  42. * Succinct documentation.
  43. */
  44. virtual const char* GetTerseDocumentation() const
  45. {
  46. return "Enable a language (CXX/C/Fortran/etc)";
  47. }
  48. /**
  49. * More documentation.
  50. */
  51. virtual const char* GetFullDocumentation() const
  52. {
  53. return
  54. " enable_language(languageName [OPTIONAL] )\n"
  55. "This command enables support for the named language in CMake. "
  56. "This is the same as the project command but does not create "
  57. "any of the extra variables that are created by the project command. "
  58. "Example languages are CXX, C, Fortran. "
  59. "If OPTIONAL is used, use the CMAKE_<languageName>_COMPILER_WORKS "
  60. "variable to check whether the language has been enabled successfully."
  61. "\n"
  62. "This command must be called on file scope (not inside a function) and "
  63. "the language enabled can only be used in the calling project or its "
  64. "subdirectories added by add_subdirectory(). Also note that at present, "
  65. "the OPTIONAL argument does not work.";
  66. }
  67. cmTypeMacro(cmEnableLanguageCommand, cmCommand);
  68. };
  69. #endif