diff options
author | Brad King <brad.king@kitware.com> | 2008-05-21 23:57:35 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2008-05-21 23:57:35 (GMT) |
commit | 23a60d561cc322e6b12feab27cb1614c3fcb779c (patch) | |
tree | 417752e05c4fe35b57450015a6388ae325e19e80 /Source | |
parent | 40d06f542c9813f8cf96a91ba3b90ce0d0945bcb (diff) | |
download | CMake-23a60d561cc322e6b12feab27cb1614c3fcb779c.zip CMake-23a60d561cc322e6b12feab27cb1614c3fcb779c.tar.gz CMake-23a60d561cc322e6b12feab27cb1614c3fcb779c.tar.bz2 |
BUG: Fix makefile generator to have link rules depend on all full path libraries that appear on the link line. This allows projects to relink when imported targets have changed.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmMakefileTargetGenerator.cxx | 45 |
1 files changed, 7 insertions, 38 deletions
diff --git a/Source/cmMakefileTargetGenerator.cxx b/Source/cmMakefileTargetGenerator.cxx index 05efc77..5e724d4 100644 --- a/Source/cmMakefileTargetGenerator.cxx +++ b/Source/cmMakefileTargetGenerator.cxx @@ -24,6 +24,7 @@ #include "cmSourceFile.h" #include "cmTarget.h" #include "cmake.h" +#include "cmComputeLinkInformation.h" #include "cmMakefileExecutableTargetGenerator.h" #include "cmMakefileLibraryTargetGenerator.h" @@ -1463,48 +1464,16 @@ void cmMakefileTargetGenerator { return; } - // Compute which library configuration to link. - cmTarget::LinkLibraryType linkType = cmTarget::OPTIMIZED; - if(cmSystemTools::UpperCase( - this->LocalGenerator->ConfigurationName.c_str()) == "DEBUG") - { - linkType = cmTarget::DEBUG; - } - // Keep track of dependencies already listed. - std::set<cmStdString> emitted; - - // A target should not depend on itself. - emitted.insert(this->Target->GetName()); // Loop over all library dependencies. - const cmTarget::LinkLibraryVectorType& tlibs = - this->Target->GetLinkLibraries(); - for(cmTarget::LinkLibraryVectorType::const_iterator lib = tlibs.begin(); - lib != tlibs.end(); ++lib) + const char* cfg = this->LocalGenerator->ConfigurationName.c_str(); + if(cmComputeLinkInformation* cli = this->Target->GetLinkInformation(cfg)) { - // skip the library if it is not general and the link type - // does not match the current target - if(lib->second != cmTarget::GENERAL && - lib->second != linkType) + std::vector<std::string> const& libDeps = cli->GetDepends(); + for(std::vector<std::string>::const_iterator j = libDeps.begin(); + j != libDeps.end(); ++j) { - continue; - } - - // Don't emit the same library twice for this target. - if(emitted.insert(lib->first).second) - { - // Depend on other CMake targets. - if(cmTarget* tgt = - this->GlobalGenerator->FindTarget(0, lib->first.c_str())) - { - const char* config = this->LocalGenerator->ConfigurationName.c_str(); - depends.push_back(tgt->GetFullPath(config, false)); - } - // depend on full path libs as well - else if(cmSystemTools::FileIsFullPath(lib->first.c_str())) - { - depends.push_back(lib->first.c_str()); - } + depends.push_back(*j); } } } |