cmOrderDirectories.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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 cmOrderDirectories_h
  4. #define cmOrderDirectories_h
  5. #include "cmConfigure.h" // IWYU pragma: keep
  6. #include <map>
  7. #include <memory>
  8. #include <set>
  9. #include <string>
  10. #include <utility>
  11. #include <vector>
  12. #include "cmsys/RegularExpression.hxx"
  13. class cmGeneratorTarget;
  14. class cmGlobalGenerator;
  15. class cmOrderDirectoriesConstraint;
  16. /** \class cmOrderDirectories
  17. * \brief Compute a safe runtime path order for a set of shared libraries.
  18. */
  19. class cmOrderDirectories
  20. {
  21. public:
  22. cmOrderDirectories(cmGlobalGenerator* gg, cmGeneratorTarget const* target,
  23. const char* purpose);
  24. ~cmOrderDirectories();
  25. cmOrderDirectories(const cmOrderDirectories&) = delete;
  26. cmOrderDirectories& operator=(const cmOrderDirectories&) = delete;
  27. void AddRuntimeLibrary(std::string const& fullPath,
  28. const char* soname = nullptr);
  29. void AddLinkLibrary(std::string const& fullPath);
  30. void AddUserDirectories(std::vector<std::string> const& extra);
  31. void AddLanguageDirectories(std::vector<std::string> const& dirs);
  32. void SetImplicitDirectories(std::set<std::string> const& implicitDirs);
  33. void SetLinkExtensionInfo(std::vector<std::string> const& linkExtensions,
  34. std::string const& removeExtRegex);
  35. std::vector<std::string> const& GetOrderedDirectories();
  36. private:
  37. cmGlobalGenerator* GlobalGenerator;
  38. cmGeneratorTarget const* Target;
  39. std::string Purpose;
  40. std::vector<std::string> OrderedDirectories;
  41. std::vector<std::unique_ptr<cmOrderDirectoriesConstraint>> ConstraintEntries;
  42. std::vector<std::unique_ptr<cmOrderDirectoriesConstraint>>
  43. ImplicitDirEntries;
  44. std::vector<std::string> UserDirectories;
  45. std::vector<std::string> LanguageDirectories;
  46. cmsys::RegularExpression RemoveLibraryExtension;
  47. std::vector<std::string> LinkExtensions;
  48. std::set<std::string> ImplicitDirectories;
  49. std::set<std::string> EmmittedConstraintSOName;
  50. std::set<std::string> EmmittedConstraintLibrary;
  51. std::vector<std::string> OriginalDirectories;
  52. std::map<std::string, int> DirectoryIndex;
  53. std::vector<int> DirectoryVisited;
  54. void CollectOriginalDirectories();
  55. int AddOriginalDirectory(std::string const& dir);
  56. void AddOriginalDirectories(std::vector<std::string> const& dirs);
  57. void FindConflicts();
  58. void FindImplicitConflicts();
  59. void OrderDirectories();
  60. void VisitDirectory(unsigned int i);
  61. void DiagnoseCycle();
  62. int WalkId;
  63. bool CycleDiagnosed;
  64. bool Computed;
  65. // Adjacency-list representation of runtime path ordering graph.
  66. // This maps from directory to those that must come *before* it.
  67. // Each entry that must come before is a pair. The first element is
  68. // the index of the directory that must come first. The second
  69. // element is the index of the runtime library that added the
  70. // constraint.
  71. using ConflictPair = std::pair<int, int>;
  72. struct ConflictList : public std::vector<ConflictPair>
  73. {
  74. };
  75. std::vector<ConflictList> ConflictGraph;
  76. // Compare directories after resolving symlinks.
  77. bool IsSameDirectory(std::string const& l, std::string const& r);
  78. bool IsImplicitDirectory(std::string const& dir);
  79. std::string const& GetRealPath(std::string const& dir);
  80. std::map<std::string, std::string> RealPaths;
  81. friend class cmOrderDirectoriesConstraint;
  82. friend class cmOrderDirectoriesConstraintLibrary;
  83. };
  84. #endif