/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying file Copyright.txt or https://cmake.org/licensing for details. */ #pragma once #include "cmConfigure.h" // IWYU pragma: keep #include #include #include #include #include #include #include #include "cmListFileCache.h" #include "cmSystemTools.h" #include "cmTargetLinkLibraryType.h" class cmGeneratorTarget; class cmSourceFile; // Basic information about each link item. class cmLinkItem { std::string String; public: // default feature: link library without decoration static const std::string DEFAULT; cmLinkItem(); cmLinkItem(std::string s, bool c, cmListFileBacktrace bt, std::string feature = DEFAULT); cmLinkItem(cmGeneratorTarget const* t, bool c, cmListFileBacktrace bt, std::string feature = DEFAULT); std::string const& AsStr() const; cmGeneratorTarget const* Target = nullptr; // The source file representing the external object (used when linking // `$`) cmSourceFile const* ObjectSource = nullptr; std::string Feature; bool Cross = false; cmListFileBacktrace Backtrace; friend bool operator<(cmLinkItem const& l, cmLinkItem const& r); friend bool operator==(cmLinkItem const& l, cmLinkItem const& r); friend std::ostream& operator<<(std::ostream& os, cmLinkItem const& item); }; class cmLinkImplItem : public cmLinkItem { public: cmLinkImplItem(); cmLinkImplItem(cmLinkItem item, bool checkCMP0027); bool CheckCMP0027 = false; }; /** The link implementation specifies the direct library dependencies needed by the object files of the target. */ struct cmLinkImplementationLibraries { // Libraries linked directly in this configuration. std::vector Libraries; // Object files linked directly in this configuration. std::vector Objects; // Libraries linked directly in other configurations. // Needed only for OLD behavior of CMP0003. std::vector WrongConfigLibraries; // Whether the list depends on a genex referencing the configuration. bool HadContextSensitiveCondition = false; }; struct cmLinkInterfaceLibraries { // Libraries listed in the interface. std::vector Libraries; // Object files listed in the interface. std::vector Objects; // Items to be included as if directly linked by the head target. std::vector HeadInclude; // Items to be excluded from direct linking by the head target. std::vector HeadExclude; // Whether the list depends on a genex referencing the head target. bool HadHeadSensitiveCondition = false; // Whether the list depends on a genex referencing the configuration. bool HadContextSensitiveCondition = false; }; struct cmLinkInterface : public cmLinkInterfaceLibraries { // Languages whose runtime libraries must be linked. std::vector Languages; std::unordered_map> LanguageRuntimeLibraries; // Shared library dependencies needed for linking on some platforms. std::vector SharedDeps; // Number of repetitions of a strongly connected component of two // or more static libraries. unsigned int Multiplicity = 0; // Libraries listed for other configurations. // Needed only for OLD behavior of CMP0003. std::vector WrongConfigLibraries; bool ImplementationIsInterface = false; // Whether the list depends on a link language genex. bool HadLinkLanguageSensitiveCondition = false; }; struct cmOptionalLinkInterface : public cmLinkInterface { bool LibrariesDone = false; bool AllDone = false; bool Exists = false; bool Explicit = false; }; struct cmHeadToLinkInterfaceMap : public std::map { }; struct cmLinkImplementation : public cmLinkImplementationLibraries { // Languages whose runtime libraries must be linked. std::vector Languages; std::unordered_map> LanguageRuntimeLibraries; // Whether the list depends on a link language genex. bool HadLinkLanguageSensitiveCondition = false; }; // Cache link implementation computation from each configuration. struct cmOptionalLinkImplementation : public cmLinkImplementation { bool LibrariesDone = false; bool LanguagesDone = false; bool HadHeadSensitiveCondition = false; }; /** Compute the link type to use for the given configuration. */ inline cmTargetLinkLibraryType CMP0003_ComputeLinkType( const std::string& config, std::vector const& debugConfigs) { // No configuration is always optimized. if (config.empty()) { return OPTIMIZED_LibraryType; } // Check if any entry in the list matches this configuration. std::string configUpper = cmSystemTools::UpperCase(config); if (cm::contains(debugConfigs, configUpper)) { return DEBUG_LibraryType; } // The current configuration is not a debug configuration. return OPTIMIZED_LibraryType; } // Parse LINK_LIBRARY genex markers. cm::optional ParseLinkFeature(std::string const& item);