diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2007-02-07 16:49:42 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2007-02-07 16:49:42 (GMT) |
commit | cbe95dffccb75692fcba71ca3c7835e1b3f286bd (patch) | |
tree | 757e9fdc74ba9b193e05abf0c521e3956585b21c | |
parent | f548dc4a06bdac0507cce22b26d5058878de8044 (diff) | |
download | CMake-cbe95dffccb75692fcba71ca3c7835e1b3f286bd.zip CMake-cbe95dffccb75692fcba71ca3c7835e1b3f286bd.tar.gz CMake-cbe95dffccb75692fcba71ca3c7835e1b3f286bd.tar.bz2 |
BUG: fix for bug 4414, find targets in the global generator for set_target_properties and add_dependencies
-rw-r--r-- | Source/cmAddDependenciesCommand.cxx | 13 | ||||
-rw-r--r-- | Source/cmSetTargetPropertiesCommand.cxx | 15 |
2 files changed, 15 insertions, 13 deletions
diff --git a/Source/cmAddDependenciesCommand.cxx b/Source/cmAddDependenciesCommand.cxx index d994073..874c816 100644 --- a/Source/cmAddDependenciesCommand.cxx +++ b/Source/cmAddDependenciesCommand.cxx @@ -15,6 +15,8 @@ =========================================================================*/ #include "cmAddDependenciesCommand.h" +#include "cmLocalGenerator.h" +#include "cmGlobalGenerator.h" // cmDependenciesCommand bool cmAddDependenciesCommand::InitialPass( @@ -28,14 +30,16 @@ bool cmAddDependenciesCommand::InitialPass( std::string target_name = args[0]; - cmTargets &tgts = this->Makefile->GetTargets(); - if (tgts.find(target_name) != tgts.end()) + cmTarget* target = + this->GetMakefile()->GetLocalGenerator()-> + GetGlobalGenerator()->FindTarget(0, target_name.c_str()); + if(target) { std::vector<std::string>::const_iterator s = args.begin(); - ++s; + ++s; // skip over target_name for (; s != args.end(); ++s) { - tgts[target_name].AddUtility(s->c_str()); + target->AddUtility(s->c_str()); } } else @@ -46,7 +50,6 @@ bool cmAddDependenciesCommand::InitialPass( return false; } - return true; } diff --git a/Source/cmSetTargetPropertiesCommand.cxx b/Source/cmSetTargetPropertiesCommand.cxx index f7910a0..342989d 100644 --- a/Source/cmSetTargetPropertiesCommand.cxx +++ b/Source/cmSetTargetPropertiesCommand.cxx @@ -15,6 +15,8 @@ =========================================================================*/ #include "cmSetTargetPropertiesCommand.h" +#include "cmLocalGenerator.h" +#include "cmGlobalGenerator.h" // cmSetTargetPropertiesCommand bool cmSetTargetPropertiesCommand::InitialPass( @@ -93,19 +95,16 @@ bool cmSetTargetPropertiesCommand std::vector<std::string> &propertyPairs, cmMakefile *mf) { - cmTargets& targets = mf->GetTargets(); - - // if the file is already in the makefile just set properites on it - cmTargets::iterator t = targets.find(tname); - if ( t != targets.end()) + cmTarget* target = + mf->GetLocalGenerator()->GetGlobalGenerator()->FindTarget(0, tname); + if ( target) { - cmTarget& target = t->second; // now loop through all the props and set them unsigned int k; for (k = 0; k < propertyPairs.size(); k = k + 2) { - target.SetProperty(propertyPairs[k].c_str(), - propertyPairs[k+1].c_str()); + target->SetProperty(propertyPairs[k].c_str(), + propertyPairs[k+1].c_str()); } } // if file is not already in the makefile, then add it |