cmGlobalVisualStudioGenerator.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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 cmGlobalVisualStudioGenerator_h
  11. #define cmGlobalVisualStudioGenerator_h
  12. #include "cmGlobalGenerator.h"
  13. /** \class cmGlobalVisualStudioGenerator
  14. * \brief Base class for global Visual Studio generators.
  15. *
  16. * cmGlobalVisualStudioGenerator provides functionality common to all
  17. * global Visual Studio generators.
  18. */
  19. class cmGlobalVisualStudioGenerator : public cmGlobalGenerator
  20. {
  21. public:
  22. cmGlobalVisualStudioGenerator();
  23. virtual ~cmGlobalVisualStudioGenerator();
  24. /**
  25. * Basic generate implementation for all VS generators.
  26. */
  27. virtual void Generate();
  28. /**
  29. * Configure CMake's Visual Studio macros file into the user's Visual
  30. * Studio macros directory.
  31. */
  32. virtual void ConfigureCMakeVisualStudioMacros();
  33. /**
  34. * Where does this version of Visual Studio look for macros for the
  35. * current user? Returns the empty string if this version of Visual
  36. * Studio does not implement support for VB macros.
  37. */
  38. virtual std::string GetUserMacrosDirectory();
  39. /**
  40. * What is the reg key path to "vsmacros" for this version of Visual
  41. * Studio?
  42. */
  43. virtual std::string GetUserMacrosRegKeyBase();
  44. enum MacroName {MacroReload, MacroStop};
  45. /**
  46. * Call the ReloadProjects macro if necessary based on
  47. * GetFilesReplacedDuringGenerate results.
  48. */
  49. virtual void CallVisualStudioMacro(MacroName m,
  50. const char* vsSolutionFile = 0);
  51. // return true if target is fortran only
  52. bool TargetIsFortranOnly(cmTarget& t);
  53. /** Get the top-level registry key for this VS version. */
  54. std::string GetRegistryBase();
  55. /** Return true if the generated build tree may contain multiple builds.
  56. i.e. "Can I build Debug and Release in the same tree?" */
  57. virtual bool IsMultiConfig() { return true; }
  58. protected:
  59. // Does this VS version link targets to each other if there are
  60. // dependencies in the SLN file? This was done for VS versions
  61. // below 8.
  62. virtual bool VSLinksDependencies() const { return true; }
  63. virtual const char* GetIDEVersion() = 0;
  64. struct TargetCompare
  65. {
  66. bool operator()(cmTarget const* l, cmTarget const* r) const;
  67. };
  68. class OrderedTargetDependSet: public std::multiset<cmTarget*, TargetCompare>
  69. {
  70. public:
  71. OrderedTargetDependSet(cmGlobalGenerator::TargetDependSet const&);
  72. };
  73. virtual bool ComputeTargetDepends();
  74. class VSDependSet: public std::set<cmStdString> {};
  75. class VSDependMap: public std::map<cmTarget*, VSDependSet> {};
  76. VSDependMap VSTargetDepends;
  77. void ComputeVSTargetDepends(cmTarget&);
  78. bool CheckTargetLinks(cmTarget& target, const char* name);
  79. std::string GetUtilityForTarget(cmTarget& target, const char*);
  80. virtual std::string WriteUtilityDepend(cmTarget*) = 0;
  81. std::string GetUtilityDepend(cmTarget* target);
  82. typedef std::map<cmTarget*, cmStdString> UtilityDependsMap;
  83. UtilityDependsMap UtilityDepends;
  84. };
  85. #endif