diff options
author | Stephen Kelly <steveire@gmail.com> | 2012-12-06 11:14:03 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2013-01-08 14:02:43 (GMT) |
commit | 765386279815f208c5f83b1ad2b66776e990feb9 (patch) | |
tree | 081056ac29f6abe71a2ce21838d488ca8120c806 /Source/cmTarget.h | |
parent | 40cf3fb95bc391519c0db4be1dc03c49e040579f (diff) | |
download | CMake-765386279815f208c5f83b1ad2b66776e990feb9.zip CMake-765386279815f208c5f83b1ad2b66776e990feb9.tar.gz CMake-765386279815f208c5f83b1ad2b66776e990feb9.tar.bz2 |
Add LINK_LIBRARIES property for direct target link dependencies
Previously we kept direct link dependencies in OriginalLinkLibraries.
The property exposes the information in the CMake language through the
get/set_property commands. We preserve the OriginalLinkLibraries value
internally to support old APIs like that for CMP0003's OLD behavior, but
the property is now authoritative. This follows up from commit d5cf644a
(Split link information processing into two steps, 2012-11-01).
This will be used later to populate the link interface properties when
exporting targets, and will later allow use of generator expressions
when linking to libraries with target_link_libraries.
Also make targets depend on the (config-specific) union of dependencies.
CMake now allows linking to dependencies or not depending on the config.
However, generated build systems are not all capable of processing
config-specific dependencies, so the targets depend on the union of
dependencies for all configs.
Diffstat (limited to 'Source/cmTarget.h')
-rw-r--r-- | Source/cmTarget.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/Source/cmTarget.h b/Source/cmTarget.h index 29c73b6..d4069fa 100644 --- a/Source/cmTarget.h +++ b/Source/cmTarget.h @@ -168,6 +168,9 @@ public: return this->LinkLibraries;} const LinkLibraryVectorType &GetOriginalLinkLibraries() const {return this->OriginalLinkLibraries;} + void GetDirectLinkLibraries(const char *config, + std::vector<std::string> &, + cmTarget *head); /** Compute the link type to use for the given configuration. */ LinkLibraryType ComputeLinkType(const char* config); @@ -622,6 +625,9 @@ private: void ProcessSourceExpression(std::string const& expr); + std::string GetDebugGeneratorExpressions(const std::string &value, + cmTarget::LinkLibraryType llt); + // The cmMakefile instance that owns this target. This should // always be set. cmMakefile* Makefile; |