diff options
author | Ken Martin <ken.martin@kitware.com> | 2005-05-24 15:17:30 (GMT) |
---|---|---|
committer | Ken Martin <ken.martin@kitware.com> | 2005-05-24 15:17:30 (GMT) |
commit | ef6c5ae23e369a3b6fd275069856d482fe7417c1 (patch) | |
tree | e0fa7f39ae0af7da8531e0b3540fe8e9ae322e26 /Source/cmGlobalUnixMakefileGenerator3.cxx | |
parent | 7157fa163c3ec559f991c6d72453f6437b7b43bc (diff) | |
download | CMake-ef6c5ae23e369a3b6fd275069856d482fe7417c1.zip CMake-ef6c5ae23e369a3b6fd275069856d482fe7417c1.tar.gz CMake-ef6c5ae23e369a3b6fd275069856d482fe7417c1.tar.bz2 |
ENH: optimization to not use requires step unless a language requires it
Diffstat (limited to 'Source/cmGlobalUnixMakefileGenerator3.cxx')
-rw-r--r-- | Source/cmGlobalUnixMakefileGenerator3.cxx | 35 |
1 files changed, 31 insertions, 4 deletions
diff --git a/Source/cmGlobalUnixMakefileGenerator3.cxx b/Source/cmGlobalUnixMakefileGenerator3.cxx index 0ed9d1e..7819b49 100644 --- a/Source/cmGlobalUnixMakefileGenerator3.cxx +++ b/Source/cmGlobalUnixMakefileGenerator3.cxx @@ -532,6 +532,7 @@ cmGlobalUnixMakefileGenerator3 // for each target Generate the rule files for each target. const cmTargets& targets = lg->GetMakefile()->GetTargets(); + bool needRequiresStep = this->NeedRequiresStep(lg); for(cmTargets::const_iterator t = targets.begin(); t != targets.end(); ++t) { if((t->second.GetType() == cmTarget::EXECUTABLE) || @@ -552,10 +553,15 @@ cmGlobalUnixMakefileGenerator3 makeTargetName += "/depend"; commands.push_back(lg->GetRecursiveMakeCall(makefileName.c_str(), makeTargetName.c_str())); - makeTargetName = localName; - makeTargetName += "/requires"; - commands.push_back(lg->GetRecursiveMakeCall(makefileName.c_str(), - makeTargetName.c_str())); + + // add requires if we need it for this generator + if (needRequiresStep) + { + makeTargetName = localName; + makeTargetName += "/requires"; + commands.push_back(lg->GetRecursiveMakeCall(makefileName.c_str(), + makeTargetName.c_str())); + } } makeTargetName = localName; makeTargetName += "/build"; @@ -717,3 +723,24 @@ cmGlobalUnixMakefileGenerator3::WriteHelpRule(std::ostream& ruleFileStream) ruleFileStream << "\n\n"; } + +bool cmGlobalUnixMakefileGenerator3 +::NeedRequiresStep(cmLocalUnixMakefileGenerator3 *lg) +{ + std::map<cmStdString,cmLocalUnixMakefileGenerator3::IntegrityCheckSet>& + checkSet = lg->GetIntegrityCheckSet(); + for(std::map<cmStdString, + cmLocalUnixMakefileGenerator3::IntegrityCheckSet>::const_iterator + l = checkSet.begin(); l != checkSet.end(); ++l) + { + std::string name = "CMAKE_NEEDS_REQUIRES_STEP_"; + name += l->first; + name += "_FLAG"; + if(lg->GetMakefile()->GetDefinition(name.c_str())) + { + return true; + } + } + + return false; +} |