From df2280a7ab47018c052a61f51e270fac63c3c006 Mon Sep 17 00:00:00 2001 From: Brad King Date: Tue, 5 Aug 2003 17:39:50 -0400 Subject: [PATCH] BUG: Fixed implementation of long dependency list support. The proxy target must have a corresponding file to work correctly. Instead of using a proxy target, we now just list one line for each dependency and then print one copy of the build rule at the end. --- Source/cmLocalUnixMakefileGenerator.cxx | 25 +++++++------------------ 1 file changed, 7 insertions(+), 18 deletions(-) diff --git a/Source/cmLocalUnixMakefileGenerator.cxx b/Source/cmLocalUnixMakefileGenerator.cxx index 64ffeb3e7..a171687c0 100644 --- a/Source/cmLocalUnixMakefileGenerator.cxx +++ b/Source/cmLocalUnixMakefileGenerator.cxx @@ -2802,35 +2802,24 @@ void cmLocalUnixMakefileGenerator::OutputMakeRule(std::ostream& fout, replace = target; m_Makefile->ExpandVariablesInString(replace); - if(depends.size() > 1) + std::string tgt = cmSystemTools::ConvertToOutputPath(replace.c_str()); + if(depends.empty()) { - // Create a proxy target collecting all the dependencies. This - // allows for very long dependency lists. - std::string tgt = cmSystemTools::ConvertToOutputPath(replace.c_str()); - for(std::vector::const_iterator dep = depends.begin(); - dep != depends.end(); ++dep) - { - replace = *dep; - m_Makefile->ExpandVariablesInString(replace); - fout << tgt.c_str() << ".dependency_list:: " << replace.c_str() << "\n"; - } - - // Forward dependencies through the proxy target. - fout << tgt.c_str() << ": " << tgt.c_str() << ".dependency_list\n"; + fout << tgt.c_str() << ":\n"; } else { - fout << cmSystemTools::ConvertToOutputPath(replace.c_str()) << ":"; - + // Split dependencies into multiple rule lines. This allows for + // very long dependency lists. for(std::vector::const_iterator dep = depends.begin(); dep != depends.end(); ++dep) { replace = *dep; m_Makefile->ExpandVariablesInString(replace); - fout << " " << replace.c_str(); + fout << tgt.c_str() << ": " << replace.c_str() << "\n"; } - fout << "\n"; } + int count = 0; for (std::vector::const_iterator i = commands.begin(); i != commands.end(); ++i)