cmExportInstallFileGenerator.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. file Copyright.txt or https://cmake.org/licensing for details. */
  3. #ifndef cmExportInstallFileGenerator_h
  4. #define cmExportInstallFileGenerator_h
  5. #include "cmConfigure.h" // IWYU pragma: keep
  6. #include "cmExportFileGenerator.h"
  7. #include "cmStateTypes.h"
  8. #include <iosfwd>
  9. #include <map>
  10. #include <set>
  11. #include <string>
  12. #include <vector>
  13. class cmGeneratorTarget;
  14. class cmGlobalGenerator;
  15. class cmInstallExportGenerator;
  16. class cmInstallTargetGenerator;
  17. class cmTargetExport;
  18. /** \class cmExportInstallFileGenerator
  19. * \brief Generate a file exporting targets from an install tree.
  20. *
  21. * cmExportInstallFileGenerator generates files exporting targets from
  22. * install an installation tree. The files are placed in a temporary
  23. * location for installation by cmInstallExportGenerator. One main
  24. * file is generated that creates the imported targets and loads
  25. * per-configuration files. Target locations and settings for each
  26. * configuration are written to these per-configuration files. After
  27. * installation the main file loads the configurations that have been
  28. * installed.
  29. *
  30. * This is used to implement the INSTALL(EXPORT) command.
  31. */
  32. class cmExportInstallFileGenerator : public cmExportFileGenerator
  33. {
  34. public:
  35. /** Construct with the export installer that will install the
  36. files. */
  37. cmExportInstallFileGenerator(cmInstallExportGenerator* iegen);
  38. /** Get the per-config file generated for each configuraiton. This
  39. maps from the configuration name to the file temporary location
  40. for installation. */
  41. std::map<std::string, std::string> const& GetConfigImportFiles()
  42. {
  43. return this->ConfigImportFiles;
  44. }
  45. /** Compute the globbing expression used to load per-config import
  46. files from the main file. */
  47. std::string GetConfigImportFileGlob();
  48. protected:
  49. // Implement virtual methods from the superclass.
  50. bool GenerateMainFile(std::ostream& os) override;
  51. void GenerateImportTargetsConfig(
  52. std::ostream& os, const std::string& config, std::string const& suffix,
  53. std::vector<std::string>& missingTargets) override;
  54. cmStateEnums::TargetType GetExportTargetType(
  55. cmTargetExport const* targetExport) const;
  56. void HandleMissingTarget(std::string& link_libs,
  57. std::vector<std::string>& missingTargets,
  58. cmGeneratorTarget* depender,
  59. cmGeneratorTarget* dependee) override;
  60. void ReplaceInstallPrefix(std::string& input) override;
  61. void ComplainAboutMissingTarget(cmGeneratorTarget* depender,
  62. cmGeneratorTarget* dependee,
  63. int occurrences);
  64. std::vector<std::string> FindNamespaces(cmGlobalGenerator* gg,
  65. const std::string& name);
  66. /** Generate the relative import prefix. */
  67. virtual void GenerateImportPrefix(std::ostream&);
  68. /** Generate the relative import prefix. */
  69. virtual void LoadConfigFiles(std::ostream&);
  70. virtual void CleanupTemporaryVariables(std::ostream&);
  71. /** Generate a per-configuration file for the targets. */
  72. virtual bool GenerateImportFileConfig(
  73. const std::string& config, std::vector<std::string>& missingTargets);
  74. /** Fill in properties indicating installed file locations. */
  75. void SetImportLocationProperty(const std::string& config,
  76. std::string const& suffix,
  77. cmInstallTargetGenerator* itgen,
  78. ImportPropertyMap& properties,
  79. std::set<std::string>& importedLocations);
  80. std::string InstallNameDir(cmGeneratorTarget* target,
  81. const std::string& config) override;
  82. cmInstallExportGenerator* IEGen;
  83. // The import file generated for each configuration.
  84. std::map<std::string, std::string> ConfigImportFiles;
  85. };
  86. #endif