| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750 | /*=========================================================================  Program:   CMake - Cross-Platform Makefile Generator  Module:    $RCSfile$  Language:  C++  Date:      $Date$  Version:   $Revision$  Copyright (c) 2002 Kitware, Inc., Insight Consortium.  All rights reserved.  See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.     This software is distributed WITHOUT ANY WARRANTY; without even      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      PURPOSE.  See the above copyright notices for more information.=========================================================================*/#include "cmGlobalGenerator.h"#include "cmLocalUnixMakefileGenerator.h"#include "cmMakefile.h"#include "cmSystemTools.h"#include "cmSourceFile.h"#include "cmMakeDepend.h"#include "cmCacheManager.h"#include "cmGeneratedFileStream.h"#include <stdio.h>cmLocalUnixMakefileGenerator::cmLocalUnixMakefileGenerator(){  m_WindowsShell = false;  m_IncludeDirective = "include";  m_MakefileVariableSize = 0;}cmLocalUnixMakefileGenerator::~cmLocalUnixMakefileGenerator(){}void cmLocalUnixMakefileGenerator::Generate(bool fromTheTop){  // suppoirt override in output directories  if (m_Makefile->GetDefinition("LIBRARY_OUTPUT_PATH"))    {    m_LibraryOutputPath = m_Makefile->GetDefinition("LIBRARY_OUTPUT_PATH");    if(m_LibraryOutputPath.size())      {      if(m_LibraryOutputPath[m_LibraryOutputPath.size() -1] != '/')        {        m_LibraryOutputPath += "/";        }      if(!cmSystemTools::MakeDirectory(m_LibraryOutputPath.c_str()))        {        cmSystemTools::Error("Error failed create "                             "LIBRARY_OUTPUT_PATH directory:",                             m_LibraryOutputPath.c_str());        }      m_Makefile->AddLinkDirectory(m_LibraryOutputPath.c_str());      }    }  if (m_Makefile->GetDefinition("EXECUTABLE_OUTPUT_PATH"))    {    m_ExecutableOutputPath =      m_Makefile->GetDefinition("EXECUTABLE_OUTPUT_PATH");    if(m_ExecutableOutputPath.size())      {      if(m_ExecutableOutputPath[m_ExecutableOutputPath.size() -1] != '/')        {        m_ExecutableOutputPath += "/";        }      if(!cmSystemTools::MakeDirectory(m_ExecutableOutputPath.c_str()))        {        cmSystemTools::Error("Error failed to create "                              "EXECUTABLE_OUTPUT_PATH directory:",                             m_ExecutableOutputPath.c_str());        }      m_Makefile->AddLinkDirectory(m_ExecutableOutputPath.c_str());      }    }  if (!fromTheTop)    {    // Generate depends     cmMakeDepend md;    md.SetMakefile(m_Makefile);    md.GenerateMakefileDependencies();    this->ProcessDepends(md);    }  // output the makefile fragment  std::string dest = m_Makefile->GetStartOutputDirectory();  dest += "/Makefile";  this->OutputMakefile(dest.c_str(), !fromTheTop); }void cmLocalUnixMakefileGenerator::AddDependenciesToSourceFile(cmDependInformation const *info,                                                          cmSourceFile *i,                                                          std::set<cmDependInformation const*> *visited){  // add info to the visited set  visited->insert(info);      // add this dependency and the recurse  // now recurse with info's dependencies  for(cmDependInformation::DependencySet::const_iterator d =         info->m_DependencySet.begin();      d != info->m_DependencySet.end(); ++d)    {    if (visited->find(*d) == visited->end())      {       if((*d)->m_FullPath != "")        {        i->GetDepends().push_back((*d)->m_FullPath);        }      this->AddDependenciesToSourceFile(*d,i,visited);      }    }}void cmLocalUnixMakefileGenerator::ProcessDepends(const cmMakeDepend &md){  // Now create cmDependInformation objects for files in the directory  cmTargets &tgts = m_Makefile->GetTargets();  for(cmTargets::iterator l = tgts.begin(); l != tgts.end(); l++)    {    std::vector<cmSourceFile*> &classes = l->second.GetSourceFiles();    for(std::vector<cmSourceFile*>::iterator i = classes.begin();         i != classes.end(); ++i)      {      if(!(*i)->GetPropertyAsBool("HEADER_FILE_ONLY"))        {        // get the depends        const cmDependInformation *info =           md.GetDependInformationForSourceFile(*(*i));                // Delete any hints from the source file's dependencies.        (*i)->GetDepends().erase((*i)->GetDepends().begin(), (*i)->GetDepends().end());        // Now add the real dependencies for the file.        if (info)          {          // create visited set          std::set<cmDependInformation const*> visited;          this->AddDependenciesToSourceFile(info,*i, &visited);          }        }      }    }}// This is where CMakeTargets.make is generatedvoid cmLocalUnixMakefileGenerator::OutputMakefile(const char* file,                                                   bool withDepends){  // Create sub directories fro aux source directories  std::vector<std::string>& auxSourceDirs =     m_Makefile->GetAuxSourceDirectories();  if( auxSourceDirs.size() )    {    // For the case when this is running as a remote build    // on unix, make the directory    for(std::vector<std::string>::iterator i = auxSourceDirs.begin();        i != auxSourceDirs.end(); ++i)      {      if(i->c_str()[0] != '/')        {        std::string dir = m_Makefile->GetCurrentOutputDirectory();        if(dir.size() && dir[dir.size()-1] != '/')          {          dir += "/";          }        dir += *i;        cmSystemTools::MakeDirectory(dir.c_str());        }      else        {        cmSystemTools::MakeDirectory(i->c_str());        }      }    }  // Create a stream that writes to a temporary file  // then does a copy at the end.   This is to allow users  // to hit control-c during the make of the makefile  cmGeneratedFileStream tempFile(file);  tempFile.SetAlwaysCopy(true);  std::ostream&  fout = tempFile.GetStream();  if(!fout)    {    cmSystemTools::Error("Error can not open for write: ", file);    return;    }  fout << "# CMAKE generated Makefile, DO NOT EDIT!\n"       << "# Generated by \"" << m_GlobalGenerator->GetName() << "\""       << " Generator, CMake Version "        << cmMakefile::GetMajorVersion() << "."        << cmMakefile::GetMinorVersion() << "\n"       << "# Generated from the following files:\n# "       << m_Makefile->GetHomeOutputDirectory() << "/CMakeCache.txt\n";  std::vector<std::string> lfiles = m_Makefile->GetListFiles();  // sort the array  std::sort(lfiles.begin(), lfiles.end(), std::less<std::string>());  // remove duplicates  std::vector<std::string>::iterator new_end =     std::unique(lfiles.begin(), lfiles.end());  lfiles.erase(new_end, lfiles.end());  for(std::vector<std::string>::const_iterator i = lfiles.begin();      i !=  lfiles.end(); ++i)    {    fout << "# " << i->c_str() << "\n";    }  fout << "\n\n";  if(!m_Makefile->IsOn("CMAKE_VERBOSE_MAKEFILE"))    {    fout << "# Suppresses display of executed commands\n";    fout << ".SILENT:\n";    }  fout << "# disable some common implicit rules to speed things up\n";  fout << ".SUFFIXES:\n";  fout << ".SUFFIXES:.hpuxmakemusthaverule\n";  // create a make variable with all of the sources for this Makefile  // for depend purposes.  fout << "CMAKE_MAKEFILE_SOURCES = ";  for(std::vector<std::string>::const_iterator i = lfiles.begin();      i !=  lfiles.end(); ++i)    {    fout << " " << cmSystemTools::ConvertToOutputPath(i->c_str());    }  // Add the cache to the list  std::string cacheFile = m_Makefile->GetHomeOutputDirectory();  cacheFile += "/CMakeCache.txt";  fout << " " << cmSystemTools::ConvertToOutputPath(cacheFile.c_str());  fout << "\n\n\n";  this->OutputMakeVariables(fout);    std::string checkCache = m_Makefile->GetHomeOutputDirectory();  checkCache += "/cmake.check_cache";  checkCache = cmSystemTools::ConvertToOutputPath(checkCache.c_str());  // Set up the default target as the VERY first target, so that make with no arguments will run it  this->    OutputMakeRule(fout,                    "Default target executed when no arguments are given to make, first make sure cmake.depends exists, cmake.check_depends is up-to-date, check the sources, then build the all target",                   "default_target",                   checkCache.c_str(),                   "$(MAKE) $(MAKESILENT) cmake.depends",                   "$(MAKE) $(MAKESILENT) cmake.check_depends",                   "$(MAKE) $(MAKESILENT) -f cmake.check_depends",                   "$(MAKE) $(MAKESILENT) all");    this->OutputTargetRules(fout);  this->OutputDependLibs(fout);  this->OutputTargets(fout);  this->OutputSubDirectoryRules(fout);  std::string dependName = m_Makefile->GetStartOutputDirectory();  dependName += "/cmake.depends";  if(withDepends)    {    std::ofstream dependout(dependName.c_str());    if(!dependout)      {       cmSystemTools::Error("Error can not open for write: ", dependName.c_str());       return;      }    dependout << "# .o dependencies in this directory." << std::endl;    std::string checkDepend = m_Makefile->GetStartOutputDirectory();    checkDepend += "/cmake.check_depends";    std::ofstream checkdependout(checkDepend.c_str());    if(!checkdependout)      {       cmSystemTools::Error("Error can not open for write: ", checkDepend.c_str());       return;      }    checkdependout << "# This file is used as a tag file, that all sources depend on.  If a source changes, then the rule to rebuild this file will cause cmake.depends to be rebuilt." << std::endl;    // if there were any depends output, then output the check depends    // information inot checkdependout    if(this->OutputObjectDepends(dependout))      {      this->OutputCheckDepends(checkdependout);      }    else      {      checkdependout << "all:\n\t@echo cmake.depends is up-to-date\n";      }    }  this->OutputCustomRules(fout);  this->OutputMakeRules(fout);  this->OutputInstallRules(fout);  // only add the depend include if the depend file exists  if(cmSystemTools::FileExists(dependName.c_str()))    {    fout << m_IncludeDirective << " cmake.depends\n";    }}#if defined(_WIN32) && ! defined(__CYGWIN__) std::string cmLocalUnixMakefileGenerator::GetOutputExtension(const char* s){  std::string sourceExtension = s;  if(sourceExtension == "def")    {    return "";    }  if(sourceExtension == "ico" || sourceExtension == "rc2")    {    return "";    }  if(sourceExtension == "rc")    {    return ".res";    }  return ".obj";}#elsestd::string cmLocalUnixMakefileGenerator::GetOutputExtension(const char*){  return ".o";}#endifstd::string cmLocalUnixMakefileGenerator::GetFullTargetName(const char* n,                                                            const cmTarget& t){  const char* targetPrefix = t.GetProperty("PREFIX");  const char* targetSuffix = t.GetProperty("SUFFIX");  const char* prefixVar = 0;  const char* suffixVar = 0;  switch(t.GetType())    {    case cmTarget::STATIC_LIBRARY:      prefixVar = "CMAKE_STATIC_LIBRARY_PREFIX";      suffixVar = "CMAKE_STATIC_LIBRARY_SUFFIX";      break;    case cmTarget::SHARED_LIBRARY:      prefixVar = "CMAKE_SHARED_LIBRARY_PREFIX";      suffixVar = "CMAKE_SHARED_LIBRARY_SUFFIX";      break;    case cmTarget::MODULE_LIBRARY:      prefixVar = "CMAKE_SHARED_MODULE_PREFIX";      suffixVar = "CMAKE_SHARED_MODULE_SUFFIX";      break;    case cmTarget::EXECUTABLE:    case cmTarget::WIN32_EXECUTABLE:      targetSuffix = cmSystemTools::GetExecutableExtension();    case cmTarget::UTILITY:    case cmTarget::INSTALL_FILES:    case cmTarget::INSTALL_PROGRAMS:      break;    }  // if there is no prefix on the target use the cmake definition  if(!targetPrefix && prefixVar)    {    targetPrefix = this->GetSafeDefinition(prefixVar);    }  // if there is no suffix on the target use the cmake definition  if(!targetSuffix && suffixVar)    {    targetSuffix = this->GetSafeDefinition(suffixVar);    }  std::string name = targetPrefix?targetPrefix:"";  name += n;  name += targetSuffix?targetSuffix:"";  return name;}// Output the rules for any targetsvoid cmLocalUnixMakefileGenerator::OutputTargetRules(std::ostream& fout){  // for each target add to the list of targets  fout << "TARGETS = ";  const cmTargets &tgts = m_Makefile->GetTargets();  // list libraries first  for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    if (l->second.IsInAll())      {      if((l->second.GetType() == cmTarget::STATIC_LIBRARY) ||         (l->second.GetType() == cmTarget::SHARED_LIBRARY) ||         (l->second.GetType() == cmTarget::MODULE_LIBRARY))        {        std::string path = m_LibraryOutputPath;        path += this->GetFullTargetName(l->first.c_str(), l->second);        fout << " \\\n"              << cmSystemTools::ConvertToOutputPath(path.c_str());        }      }    }  // executables  for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    if ((l->second.GetType() == cmTarget::EXECUTABLE ||         l->second.GetType() == cmTarget::WIN32_EXECUTABLE) &&        l->second.IsInAll())      {      std::string path = m_ExecutableOutputPath;      path += this->GetFullTargetName(l->first.c_str(), l->second);      fout << " \\\n" << cmSystemTools::ConvertToOutputPath(path.c_str());      }    }  // list utilities last  for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    if (l->second.GetType() == cmTarget::UTILITY &&        l->second.IsInAll())      {      fout << " \\\n" << l->first.c_str();      }    }  fout << "\n\n";  // get the classes from the source lists then add them to the groups  for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    std::vector<cmSourceFile*> classes = l->second.GetSourceFiles();    if (classes.begin() != classes.end())      {      fout << this->CreateMakeVariable(l->first.c_str(), "_SRC_OBJS") << " = ";      for(std::vector<cmSourceFile*>::iterator i = classes.begin();           i != classes.end(); i++)        {        if(!(*i)->GetPropertyAsBool("HEADER_FILE_ONLY"))          {          std::string outExt(            this->GetOutputExtension((*i)->GetSourceExtension().c_str()));          if(outExt.size())            {            fout << "\\\n"                  << cmSystemTools::ConvertToOutputPath((*i)->GetSourceName().c_str())                 << outExt.c_str() << " ";            }          }        }      fout << "\n\n";      fout << this->CreateMakeVariable(l->first.c_str(), "_SRC_OBJS_QUOTED") << " = ";      for(std::vector<cmSourceFile*>::iterator i = classes.begin();           i != classes.end(); i++)        {        if(!(*i)->GetPropertyAsBool("HEADER_FILE_ONLY"))          {          std::string outExt(this->GetOutputExtension((*i)->GetSourceExtension().c_str()));          if(outExt.size())            {            fout << "\\\n\"" << cmSystemTools::ConvertToOutputPath((*i)->GetSourceName().c_str())                 << outExt.c_str() << "\" ";            }          }        }      fout << "\n\n";      }    }  fout << "CLEAN_OBJECT_FILES = ";  for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    std::vector<cmSourceFile*> classes = l->second.GetSourceFiles();    if (classes.begin() != classes.end())      {      fout << "$(" << this->CreateMakeVariable(l->first.c_str(), "_SRC_OBJS")           << ") ";      }    }  fout << "\n\n";  const char * qt_files = m_Makefile->GetDefinition("GENERATED_QT_FILES");  if (qt_files != NULL &&       strlen(m_Makefile->GetDefinition("GENERATED_QT_FILES"))>0)    {    fout << "GENERATED_QT_FILES = ";    fout << qt_files;    fout << "\n\n";    }}/** * Output the linking rules on a command line.  For executables, * targetLibrary should be a NULL pointer.  For libraries, it should point * to the name of the library.  This will not link a library against itself. */void cmLocalUnixMakefileGenerator::OutputLinkLibraries(std::ostream& fout,                                                  const char* targetLibrary,                                                  const cmTarget &tgt){  // Try to emit each search path once  std::set<std::string> emitted;  // Embed runtime search paths if possible and if required.  bool outputRuntime = true;  std::string runtimeFlag;  std::string runtimeSep;  std::vector<std::string> runtimeDirs;  bool cxx = tgt.HasCxx();   if(!cxx )    {    // if linking a c executable use the C runtime flag as cc    // may not be the same program that creates shared libaries    // and may have different flags    runtimeFlag = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_RUNTIME_FLAG");    runtimeSep = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_RUNTIME_FLAG_SEP");    }  else    {     runtimeFlag = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG");    runtimeSep = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_RUNTIME_CXX_FLAG_SEP");    }    // concatenate all paths or no?  bool runtimeConcatenate = ( runtimeSep!="" );  if(runtimeFlag == "" || m_Makefile->IsOn("CMAKE_SKIP_RPATH") )    {    outputRuntime = false;    }  // Some search paths should never be emitted  emitted.insert("");  emitted.insert("/usr/lib");  std::string libPathFlag = m_Makefile->GetDefinition("CMAKE_LIBRARY_PATH_FLAG");  std::string libLinkFlag = this->GetSafeDefinition("CMAKE_LINK_LIBRARY_FLAG");  // collect all the flags needed for linking libraries  std::string linkLibs;    // Flags to link an executable to shared libraries.  if( tgt.GetType() == cmTarget::EXECUTABLE)    {    if(cxx)      {      linkLibs = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS");      }    else      {      linkLibs = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_LINK_FLAGS");      }    linkLibs += " ";    }    const std::vector<std::string>& libdirs = tgt.GetLinkDirectories();  for(std::vector<std::string>::const_iterator libDir = libdirs.begin();      libDir != libdirs.end(); ++libDir)    {     std::string libpath = this->ConvertToOutputForExisting(libDir->c_str());    if(emitted.insert(libpath).second)      {      std::string::size_type pos = libDir->find(libPathFlag.c_str());      if((pos == std::string::npos || pos > 0)         && libDir->find("${") == std::string::npos)        {        linkLibs += libPathFlag;        if(outputRuntime)          {          runtimeDirs.push_back( libpath );          }        }      linkLibs += libpath;      linkLibs += " ";      }    }  std::string linkSuffix = this->GetSafeDefinition("CMAKE_LINK_LIBRARY_SUFFIX");  std::string regexp = ".*\\";  regexp += linkSuffix;  regexp += "$";  cmRegularExpression hasSuffix(regexp.c_str());  std::string librariesLinked;  const cmTarget::LinkLibraries& libs = tgt.GetLinkLibraries();  for(cmTarget::LinkLibraries::const_iterator lib = libs.begin();      lib != libs.end(); ++lib)    {    // Don't link the library against itself!    if(targetLibrary && (lib->first == targetLibrary)) continue;    // don't look at debug libraries    if (lib->second == cmTarget::DEBUG) continue;    // skip zero size library entries, this may happen    // if a variable expands to nothing.    if (lib->first.size() == 0) continue;    // if it is a full path break it into -L and -l    cmRegularExpression reg("([ \t]*\\-l)|([ \t]*\\-framework)|(\\${)");    if(lib->first.find('/') != std::string::npos       && !reg.find(lib->first))      {      std::string dir, file;      cmSystemTools::SplitProgramPath(lib->first.c_str(),                                      dir, file);      std::string libpath = this->ConvertToOutputForExisting(dir.c_str());      if(emitted.insert(libpath).second)        {        linkLibs += libPathFlag;        linkLibs += libpath;        linkLibs += " ";        if(outputRuntime)          {          runtimeDirs.push_back( libpath );          }        }        cmRegularExpression libname("lib([^/]*)(\\.so|\\.lib|\\.dll|\\.sl|\\.a|\\.dylib).*");      cmRegularExpression libname_noprefix("([^/]*)(\\.so|\\.lib|\\.dll|\\.sl|\\.a|\\.dylib).*");      if(libname.find(file))        {        // Library had "lib" prefix.        librariesLinked += libLinkFlag;        file = libname.match(1);        librariesLinked += file;        if(linkSuffix.size() && !hasSuffix.find(file))          {          librariesLinked += linkSuffix;          }        librariesLinked += " ";        }      else if(libname_noprefix.find(file))        {        // Library had no "lib" prefix.        librariesLinked += libLinkFlag;        file = libname_noprefix.match(1);        librariesLinked += file;        if(linkSuffix.size() && !hasSuffix.find(file))          {          librariesLinked +=  linkSuffix;          }        librariesLinked += " ";        }      else        {        // Error parsing the library name.  Just use the full path.        // The linker will give an error if it is invalid.        librariesLinked += lib->first;        librariesLinked += " ";        }      }    // not a full path, so add -l name    else      {      if(!reg.find(lib->first))        {        librariesLinked += libLinkFlag;        }      librariesLinked += lib->first;      if(linkSuffix.size() && !hasSuffix.find(lib->first))        {        librariesLinked += linkSuffix;        }      librariesLinked += " ";      }    }  linkLibs += librariesLinked;  fout << linkLibs;  if(outputRuntime && runtimeDirs.size()>0)    {    // For the runtime search directories, do a "-Wl,-rpath,a:b:c" or    // a "-R a -R b -R c" type link line    fout << runtimeFlag;    std::vector<std::string>::iterator itr = runtimeDirs.begin();    fout << *itr;    ++itr;    for( ; itr != runtimeDirs.end(); ++itr )      {      if(runtimeConcatenate)        {        fout << runtimeSep << *itr;        }      else        {        fout << " " << runtimeFlag << *itr;        }      }    fout << " ";    }  if(m_Makefile->GetDefinition("CMAKE_STANDARD_LIBRARIES"))    {    fout << m_Makefile->GetDefinition("CMAKE_STANDARD_LIBRARIES") << " ";    }}std::string cmLocalUnixMakefileGenerator::CreateTargetRules(const cmTarget &target,                                                       const char* targetName){  std::string customRuleCode = "";  bool initNext = false;  for (std::vector<cmCustomCommand>::const_iterator cr =          target.GetCustomCommands().begin();        cr != target.GetCustomCommands().end(); ++cr)    {    cmCustomCommand cc(*cr);    cc.ExpandVariables(*m_Makefile);    if (cc.GetSourceName() == targetName)      {      if(initNext)        {        customRuleCode += "\n\t";        }      else        {        initNext = true;        }      std::string command = cmSystemTools::ConvertToOutputPath(cc.GetCommand().c_str());      customRuleCode += command + " " + cc.GetArguments();      }    }  return customRuleCode;}struct RuleVariables{  const char* replace;  const char* lookup;};static RuleVariables ruleReplaceVars[] ={  {"<CMAKE_SHARED_LIBRARY_CREATE_CXX_FLAGS>", "CMAKE_SHARED_LIBRARY_CREATE_CXX_FLAGS"},  {"<CMAKE_SHARED_MODULE_CREATE_CXX_FLAGS>", "CMAKE_SHARED_MODULE_CREATE_CXX_FLAGS"},   {"<CMAKE_SHARED_MODULE_C_FLAGS>", "CMAKE_SHARED_MODULE_C_FLAGS"},  {"<CMAKE_SHARED_MODULE_CXX_FLAGS>", "CMAKE_SHARED_MODULE_CXX_FLAGS"},  {"<CMAKE_SHARED_LIBRARY_C_FLAGS>", "CMAKE_SHARED_LIBRARY_C_FLAGS"},  {"<CMAKE_SHARED_LIBRARY_CXX_FLAGS>", "CMAKE_SHARED_LIBRARY_CXX_FLAGS"},  {"<CMAKE_CXX_LINK_FLAGS>", "CMAKE_CXX_LINK_FLAGS"},  {"<CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS>", "CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS"},  {"<CMAKE_SHARED_MODULE_CREATE_C_FLAGS>", "CMAKE_SHARED_MODULE_CREATE_C_FLAGS"},   {"<CMAKE_C_LINK_FLAGS>", "CMAKE_C_LINK_FLAGS"},  {"<CMAKE_AR>", "CMAKE_AR"},  {"<CMAKE_RANLIB>", "CMAKE_RANLIB"},  {0, 0}}; void cmLocalUnixMakefileGenerator::ExpandRuleVariables(std::string& s,                                                  const char* objects,                                                  const char* target,                                                  const char* linkLibs,                                                  const char* source,                                                  const char* object,                                                  const char* flags,                                                  const char* objectsquoted,                                                  const char* targetBase,                                                  const char* linkFlags){   std::string cxxcompiler = this->ConvertToOutputForExisting(    this->GetSafeDefinition("CMAKE_CXX_COMPILER"));  std::string ccompiler = this->ConvertToOutputForExisting(    this->GetSafeDefinition("CMAKE_C_COMPILER"));  cmSystemTools::ReplaceString(s, "<CMAKE_CXX_COMPILER>", cxxcompiler.c_str());  cmSystemTools::ReplaceString(s, "<CMAKE_C_COMPILER>", ccompiler.c_str());  if(linkFlags)    {    cmSystemTools::ReplaceString(s, "<LINK_FLAGS>", linkFlags);    }  if(flags)    {    cmSystemTools::ReplaceString(s, "<FLAGS>", flags);    }      if(source)    {    cmSystemTools::ReplaceString(s, "<SOURCE>", source);    }  if(object)    {    cmSystemTools::ReplaceString(s, "<OBJECT>", object);    }  if(objects)    {    cmSystemTools::ReplaceString(s, "<OBJECTS>", objects);    }  if(objectsquoted)    {    cmSystemTools::ReplaceString(s, "<OBJECTS_QUOTED>", objectsquoted);    }  if(target)    {    cmSystemTools::ReplaceString(s, "<TARGET>", target);    }  if(targetBase)    {    // special case for quoted paths with spaces     // if you see <TARGET_BASE>.lib then put the .lib inside    // the quotes, same for .dll    if((strlen(targetBase) > 1) && targetBase[0] == '\"')      {      std::string base = targetBase;      base[base.size()-1] = '.';      std::string baseLib = base + "lib\"";      std::string baseDll = base + "dll\"";      cmSystemTools::ReplaceString(s, "<TARGET_BASE>.lib", baseLib.c_str());      cmSystemTools::ReplaceString(s, "<TARGET_BASE>.dll", baseDll.c_str());      }    cmSystemTools::ReplaceString(s, "<TARGET_BASE>", targetBase);    }  if(linkLibs)    {    cmSystemTools::ReplaceString(s, "<LINK_LIBRARIES>", linkLibs);    }    RuleVariables* rv = ruleReplaceVars;  while(rv->replace)    {    cmSystemTools::ReplaceString(s, rv->replace,                                 this->GetSafeDefinition(rv->lookup));    rv++;    }  }  void cmLocalUnixMakefileGenerator::OutputLibraryRule(std::ostream& fout,                                                       const char* name,                                                      const cmTarget &t,                                                     const char* prefix,                                                     const char* suffix,                                                     const char* createVariable,                                                     const char* comment,                                                     const char* linkFlags                                                     ){  // create the library name  std::string targetNameBase = prefix;  targetNameBase += name;    std::string targetName = prefix;  targetName += name;  targetName +=  suffix;  // create the target full path name  std::string targetFullPath = m_LibraryOutputPath + targetName;  std::string targetBaseFullPath = m_LibraryOutputPath + targetNameBase;  targetBaseFullPath =    cmSystemTools::ConvertToOutputPath(targetBaseFullPath.c_str());  targetFullPath = cmSystemTools::ConvertToOutputPath(targetFullPath.c_str());  // get the objects that are used to link this library  std::string objs = "$(" + this->CreateMakeVariable(name, "_SRC_OBJS") + ") ";  std::string objsQuoted = "$(" + this->CreateMakeVariable(name, "_SRC_OBJS_QUOTED") + ") ";  // create a variable with the objects that this library depends on  std::string depend = objs + " $("     + this->CreateMakeVariable(name, "_DEPEND_LIBS") + ")";  // collect up the build rules  std::vector<std::string> rules;  std::string command = "$(RM) " +  targetFullPath;  rules.push_back(command);  rules.push_back(m_Makefile->GetDefinition(createVariable));  // expand multi-command semi-colon separated lists  // of commands into separate commands  std::vector<std::string> commands;  cmSystemTools::ExpandList(rules, commands);  // collect custom commands for this target and add them to the list  std::string customCommands = this->CreateTargetRules(t, name);  if(customCommands.size() > 0)    {    commands.push_back(customCommands);    }  // collect up the link libraries  cmOStringStream linklibs;  this->OutputLinkLibraries(linklibs, name, t);  for(std::vector<std::string>::iterator i = commands.begin();      i != commands.end(); ++i)    {    this->ExpandRuleVariables(*i,                               objs.c_str(),                               targetFullPath.c_str(),                              linklibs.str().c_str(),                              0, 0, 0, objsQuoted.c_str(),                              targetBaseFullPath.c_str(),                              linkFlags);    }  this->OutputMakeRule(fout, comment,                       targetFullPath.c_str(),                       depend.c_str(),                       commands);}void cmLocalUnixMakefileGenerator::OutputSharedLibraryRule(std::ostream& fout,                                                             const char* name,                                                            const cmTarget &t){  const char* createRule;  if(t.HasCxx())    {    createRule = "CMAKE_CXX_CREATE_SHARED_LIBRARY";    }  else    {    createRule = "CMAKE_C_CREATE_SHARED_LIBRARY";    }  std::string buildType =  this->GetSafeDefinition("CMAKE_BUILD_TYPE");  buildType = cmSystemTools::UpperCase(buildType);   std::string linkFlags = this->GetSafeDefinition("CMAKE_SHARED_LINKER_FLAGS");  linkFlags += " ";  if(buildType.size())    {    std::string build = "CMAKE_SHARED_LINKER_FLAGS_";    build += buildType;    linkFlags += this->GetSafeDefinition(build.c_str());    linkFlags += " ";    }#ifdef _WIN32  const std::vector<cmSourceFile*>& sources = t.GetSourceFiles();  for(std::vector<cmSourceFile*>::const_iterator i = sources.begin();      i != sources.end(); ++i)    {    if((*i)->GetSourceExtension() == "def")      {      linkFlags += this->GetSafeDefinition("CMAKE_LINK_DEF_FILE_FLAG");      linkFlags += (*i)->GetFullPath();      linkFlags += " ";      }    }#endif  const char* targetPrefix = t.GetProperty("PREFIX");  if(!targetPrefix)    {    targetPrefix = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_PREFIX");    }  const char* targetSuffix = t.GetProperty("SUFFIX");  if(!targetSuffix)    {    targetSuffix = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_SUFFIX");    }  const char* targetLinkFlags = t.GetProperty("LINK_FLAGS");  if(targetLinkFlags)    {    linkFlags += targetLinkFlags;    linkFlags += " ";    }  this->OutputLibraryRule(fout, name, t,                          targetPrefix,                          targetSuffix,                          createRule,                          "shared library",                          linkFlags.c_str());}void cmLocalUnixMakefileGenerator::OutputModuleLibraryRule(std::ostream& fout,                                                       const char* name,                                                       const cmTarget &t){  const char* createRule;  if(t.HasCxx())    {    createRule = "CMAKE_CXX_CREATE_SHARED_MODULE";    }  else    {    createRule = "CMAKE_C_CREATE_SHARED_MODULE";    }  std::string buildType =  this->GetSafeDefinition("CMAKE_BUILD_TYPE");  buildType = cmSystemTools::UpperCase(buildType);   std::string linkFlags = this->GetSafeDefinition("CMAKE_MODULE_LINKER_FLAGS");  linkFlags += " ";  if(buildType.size())    {    std::string build = "CMAKE_MODULE_LINKER_FLAGS_";    build += buildType;    linkFlags += this->GetSafeDefinition(build.c_str());    linkFlags += " ";    }  const char* targetPrefix = t.GetProperty("PREFIX");  if(!targetPrefix)    {    targetPrefix = this->GetSafeDefinition("CMAKE_SHARED_MODULE_PREFIX");    }  const char* targetSuffix = t.GetProperty("SUFFIX");  if(!targetSuffix)    {    targetSuffix = this->GetSafeDefinition("CMAKE_SHARED_MODULE_SUFFIX");    }  const char* targetLinkFlags = t.GetProperty("LINK_FLAGS");  if(targetLinkFlags)    {    linkFlags += targetLinkFlags;    linkFlags += " ";    }  this->OutputLibraryRule(fout, name, t,                          targetPrefix,                          targetSuffix,                          createRule,                          "shared module",                          linkFlags.c_str());}void cmLocalUnixMakefileGenerator::OutputStaticLibraryRule(std::ostream& fout,                                                      const char* name,                                                       const cmTarget &t){  const char* createRule;  if(t.HasCxx())    {    createRule = "CMAKE_CXX_CREATE_STATIC_LIBRARY";    }  else    {    createRule = "CMAKE_C_CREATE_STATIC_LIBRARY";    }    const char* targetPrefix = t.GetProperty("PREFIX");  if(!targetPrefix)    {    targetPrefix = this->GetSafeDefinition("CMAKE_STATIC_LIBRARY_PREFIX");    }  const char* targetSuffix = t.GetProperty("SUFFIX");  if(!targetSuffix)    {    targetSuffix = this->GetSafeDefinition("CMAKE_STATIC_LIBRARY_SUFFIX");    }  std::string linkFlags;  const char* targetLinkFlags = t.GetProperty("LINK_FLAGS");  if(targetLinkFlags)    {    linkFlags += targetLinkFlags;    linkFlags += " ";    }  this->OutputLibraryRule(fout, name, t,                          targetPrefix,                          targetSuffix,                          createRule,                          "static library",                          linkFlags.c_str());  }void cmLocalUnixMakefileGenerator::OutputExecutableRule(std::ostream& fout,                                                        const char* name,                                                        const cmTarget &t){  std::string linkFlags;  std::string buildType =  this->GetSafeDefinition("CMAKE_BUILD_TYPE");  buildType = cmSystemTools::UpperCase(buildType);  std::string flags;  std::string target = m_ExecutableOutputPath + name     + cmSystemTools::GetExecutableExtension();   target = cmSystemTools::ConvertToOutputPath(target.c_str());  std::string objs = "$(" + this->CreateMakeVariable(name, "_SRC_OBJS") + ") ";  std::string depend = "$(";  depend += this->CreateMakeVariable(name, "_SRC_OBJS")     + ") $(" + this->CreateMakeVariable(name, "_DEPEND_LIBS") + ")";  std::vector<std::string> rules;  linkFlags += this->GetSafeDefinition("CMAKE_EXE_LINKER_FLAGS");  linkFlags += " ";  if(buildType.size())    {    std::string build = "CMAKE_EXE_LINKER_FLAGS_";    build += buildType;    linkFlags += this->GetSafeDefinition(build.c_str());    linkFlags += " ";    }  if(t.HasCxx())    {    rules.push_back(m_Makefile->GetDefinition("CMAKE_CXX_LINK_EXECUTABLE"));    flags += this->GetSafeDefinition("CMAKE_CXX_FLAGS");    flags += " ";    flags += this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_CXX_FLAGS");    flags += " ";    }  else    {    flags += this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_LINK_FLAGS");    flags += " ";    rules.push_back(m_Makefile->GetDefinition("CMAKE_C_LINK_EXECUTABLE"));    flags += this->GetSafeDefinition("CMAKE_C_FLAGS");    flags += " ";    }  cmOStringStream linklibs;  this->OutputLinkLibraries(linklibs, 0, t);  std::string comment = "executable";    std::vector<std::string> commands;  cmSystemTools::ExpandList(rules, commands);  std::string customCommands = this->CreateTargetRules(t, name);  if(customCommands.size() > 0)    {    commands.push_back(customCommands.c_str());    }  if(cmSystemTools::IsOn(m_Makefile->GetDefinition("BUILD_SHARED_LIBS")))    {    linkFlags += this->GetSafeDefinition("CMAKE_SHARED_BUILD_CXX_FLAGS");    linkFlags += " ";   }    if(t.GetType() == cmTarget::WIN32_EXECUTABLE)    {    linkFlags +=  this->GetSafeDefinition("CMAKE_CREATE_WIN32_EXE");    linkFlags += " ";    }  else    {    linkFlags +=  this->GetSafeDefinition("CMAKE_CREATE_CONSOLE_EXE");    linkFlags += " ";    }  const char* targetLinkFlags = t.GetProperty("LINK_FLAGS");  if(targetLinkFlags)    {    linkFlags += targetLinkFlags;    linkFlags += " ";    }  for(std::vector<std::string>::iterator i = commands.begin();      i != commands.end(); ++i)    {    this->ExpandRuleVariables(*i,                               objs.c_str(),                               target.c_str(),                              linklibs.str().c_str(),                              0,                              0,                              flags.c_str(),                              0,                              0,                              linkFlags.c_str());    }  this->OutputMakeRule(fout,                        comment.c_str(),                       target.c_str(),                       depend.c_str(),                       commands);}void cmLocalUnixMakefileGenerator::OutputUtilityRule(std::ostream& fout,                                                const char* name,                                                const cmTarget &t){  std::string customCommands = this->CreateTargetRules(t, name);  const char* cc = 0;  if(customCommands.size() > 0)    {    cc = customCommands.c_str();    }  std::string comment = "Utility";  std::string depends;  std::string replaceVars;  const std::vector<cmCustomCommand> &ccs = t.GetCustomCommands();  for(std::vector<cmCustomCommand>::const_iterator i = ccs.begin();      i != ccs.end(); ++i)    {    const std::vector<std::string>  & dep = i->GetDepends();    for(std::vector<std::string>::const_iterator d = dep.begin();        d != dep.end(); ++d)      {      depends +=  " \\\n";      replaceVars = *d;      m_Makefile->ExpandVariablesInString(replaceVars);      depends += cmSystemTools::ConvertToOutputPath(replaceVars.c_str());      }    }  this->OutputMakeRule(fout, comment.c_str(), name,                       depends.c_str(), cc);}  void cmLocalUnixMakefileGenerator::OutputTargets(std::ostream& fout){  // for each target  const cmTargets &tgts = m_Makefile->GetTargets();  for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    switch(l->second.GetType())      {      case cmTarget::STATIC_LIBRARY:        this->OutputStaticLibraryRule(fout, l->first.c_str(), l->second);        break;      case cmTarget::SHARED_LIBRARY:        this->OutputSharedLibraryRule(fout, l->first.c_str(), l->second);        break;      case cmTarget::MODULE_LIBRARY:        this->OutputModuleLibraryRule(fout, l->first.c_str(), l->second);        break;      case cmTarget::EXECUTABLE:      case cmTarget::WIN32_EXECUTABLE:        this->OutputExecutableRule(fout, l->first.c_str(), l->second);        break;      case cmTarget::UTILITY:        this->OutputUtilityRule(fout, l->first.c_str(), l->second);        break;        // This is handled by the OutputCustomRules method      case cmTarget::INSTALL_FILES:        // This is handled by the OutputInstallRules method      case cmTarget::INSTALL_PROGRAMS:        // This is handled by the OutputInstallRules method        break;      }    }}// For each target that is an executable or shared library, generate// the "<name>_DEPEND_LIBS" variable listing its library dependencies.void cmLocalUnixMakefileGenerator::OutputDependLibs(std::ostream& fout){  // Build a set of libraries that will be linked into any target in  // this directory.  std::set<std::string> used;    // for each target  const cmTargets &tgts = m_Makefile->GetTargets();    for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    // Each dependency should only be emitted once per target.    std::set<std::string> emitted;    if ((l->second.GetType() == cmTarget::SHARED_LIBRARY)        || (l->second.GetType() == cmTarget::MODULE_LIBRARY)        || (l->second.GetType() == cmTarget::STATIC_LIBRARY)        || (l->second.GetType() == cmTarget::EXECUTABLE)        || (l->second.GetType() == cmTarget::WIN32_EXECUTABLE))      {      fout << this->CreateMakeVariable(l->first.c_str(), "_DEPEND_LIBS") << " = ";            // A library should not depend on itself!      emitted.insert(l->first);      // for static libraries do not depend on other libraries      if(l->second.GetType() != cmTarget::STATIC_LIBRARY)        {        // Now, look at all link libraries specific to this target.        const cmTarget::LinkLibraries& tlibs = l->second.GetLinkLibraries();        for(cmTarget::LinkLibraries::const_iterator lib = tlibs.begin();            lib != tlibs.end(); ++lib)          {          // Record that this library was used.          used.insert(lib->first);                    // Don't emit the same library twice for this target.          if(emitted.insert(lib->first).second)            {            // Output this dependency.            this->OutputLibDepend(fout, lib->first.c_str());            }          }        }      // for all targets depend on utilities      // Now, look at all utilities specific to this target.      const std::set<cmStdString>& tutils = l->second.GetUtilities();      for(std::set<cmStdString>::const_iterator util = tutils.begin();          util != tutils.end(); ++util)        {         // Record that this utility was used.        used.insert(*util);        // Don't emit the same utility twice for this target.        if(emitted.insert(*util).second)          {          // Output this dependency.          this->OutputExeDepend(fout, util->c_str());          }        }      fout << "\n";      }    }  fout << "\n";    // Loop over the libraries used and make sure there is a rule to  // build them in this makefile.  If the library is in another  // directory, add a rule to jump to that directory and make sure it  // exists.  for(std::set<std::string>::const_iterator lib = used.begin();      lib != used.end(); ++lib)    {    // loop over the list of directories that the libraries might    // be in, looking for an ADD_LIBRARY(lib...) line. This would    // be stored in the cache    std::string libPath = *lib + "_CMAKE_PATH";    const char* cacheValue = m_Makefile->GetDefinition(libPath.c_str());    // if cache and not the current directory add a rule, to    // jump into the directory and build for the first time    if(cacheValue &&       (!this->SamePath(m_Makefile->GetCurrentOutputDirectory(), cacheValue)))      {      // add the correct extension      std::string ltname = *lib+"_LIBRARY_TYPE";      const char* libType        = m_Makefile->GetDefinition(ltname.c_str());      // if it was a library..      if (libType)        {        std::string library;        std::string libpath = cacheValue;        if(libType && std::string(libType) == "SHARED")          {          library = this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_PREFIX");          library += *lib;          library += this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_SUFFIX");          }        else if(libType && std::string(libType) == "MODULE")          {          library = this->GetSafeDefinition("CMAKE_SHARED_MODULE_PREFIX");          library += *lib;          library += this->GetSafeDefinition("CMAKE_SHARED_MODULE_SUFFIX");          }        else if(libType && std::string(libType) == "STATIC")          {          library = this->GetSafeDefinition("CMAKE_STATIC_LIBRARY_PREFIX");          library += *lib;          library += this->GetSafeDefinition("CMAKE_STATIC_LIBRARY_SUFFIX");          }        else          {          cmSystemTools::Error("Unknown library type!");          return;          }        if(m_LibraryOutputPath.size())          {          libpath = m_LibraryOutputPath;          }        else          {          libpath += "/";          }        libpath += library;        // put out a rule to build the library if it does not exist        this->OutputBuildTargetInDir(fout,                                     cacheValue,                                     library.c_str(),                                     libpath.c_str(),                                     m_Makefile->                                     GetDefinition("LIBRARY_OUTPUT_PATH")                                     );        }      // something other than a library...      else        {        std::string exepath = cacheValue;        if(m_ExecutableOutputPath.size())          {          exepath = m_ExecutableOutputPath;          }        else          {          exepath += "/";          }        std::string fullName = lib->c_str();        fullName += cmSystemTools::GetExecutableExtension();        exepath += fullName;        this->OutputBuildTargetInDir(fout,                                     cacheValue,                                     fullName.c_str(),                                     exepath.c_str(),                                     m_Makefile->                                     GetDefinition("EXECUTABLE_OUTPUT_PATH")          );        }      }    }}void cmLocalUnixMakefileGenerator::OutputBuildTargetInDirWindows(std::ostream& fout,                                                                 const char* path,                                                                 const char* library,                                                                 const char* fullpath,                                                                 const char* libOutPath){  const char* makeTarget = library;  std::string currentDir =     cmSystemTools::ConvertToOutputPath(m_Makefile->GetCurrentOutputDirectory());  std::string wpath = this->ConvertToOutputForExisting(path);  std::string wfullpath = this->ConvertToOutputForExisting(fullpath);  if(libOutPath && strcmp( libOutPath, "" ) != 0)    {    makeTarget = wfullpath.c_str();    }  fout << wfullpath       << ":\n\tcd " << wpath  << "\n"       << "\t$(MAKE) -$(MAKEFLAGS) $(MAKESILENT) cmake.depends\n"       << "\t$(MAKE) -$(MAKEFLAGS) $(MAKESILENT) cmake.check_depends\n"       << "\t$(MAKE) -$(MAKEFLAGS) $(MAKESILENT) -f cmake.check_depends\n"       << "\t$(MAKE) $(MAKESILENT) " << makeTarget       << "\n\tcd " << currentDir << "\n";}void cmLocalUnixMakefileGenerator::OutputBuildTargetInDir(std::ostream& fout,                                                     const char* path,                                                     const char* library,                                                     const char* fullpath,                                                     const char* outputPath){  if(m_WindowsShell)    {    this->OutputBuildTargetInDirWindows(fout, path, library, fullpath, outputPath);    return;    }  const char* makeTarget = library;  if(outputPath && strcmp( outputPath, "" ) != 0)    {    makeTarget = fullpath;    }  fout << this->ConvertToOutputForExisting(fullpath)       << ":\n\tcd " << this->ConvertToOutputForExisting(path)       << "; $(MAKE) $(MAKESILENT) cmake.depends"       << "; $(MAKE) $(MAKESILENT) cmake.check_depends"       << "; $(MAKE) $(MAKESILENT) -f cmake.check_depends"       << "; $(MAKE) $(MAKESILENT) "       << cmSystemTools::ConvertToOutputPath(makeTarget) << "\n\n"; }bool cmLocalUnixMakefileGenerator::SamePath(const char* path1, const char* path2){  if (strcmp(path1, path2) == 0)    {    return true;    }#if defined(_WIN32) || defined(__APPLE__)  return     cmSystemTools::LowerCase(this->ConvertToOutputForExisting(path1)) ==    cmSystemTools::LowerCase(this->ConvertToOutputForExisting(path2));#else  return false;#endif}void cmLocalUnixMakefileGenerator::OutputLibDepend(std::ostream& fout,                                              const char* name){  std::string libPath = name;  libPath += "_CMAKE_PATH";  const char* cacheValue = m_Makefile->GetDefinition(libPath.c_str());  if(cacheValue )    {    // if there is a cache value, then this is a library that cmake    // knows how to build, so we can depend on it    std::string libpath;    if (!this->SamePath(m_Makefile->GetCurrentOutputDirectory(), cacheValue))      {      // if the library is not in the current directory, then get the full      // path to it      if(m_LibraryOutputPath.size())        {        libpath = m_LibraryOutputPath;        }      else        {        libpath = cacheValue;        libpath += "/";        }      }    else      {      // library is in current Makefile so use lib as a prefix      libpath = m_LibraryOutputPath;      }    // add the correct extension    std::string ltname = name;    ltname += "_LIBRARY_TYPE";    const char* libType = m_Makefile->GetDefinition(ltname.c_str());    if(libType && std::string(libType) == "SHARED")      {      libpath += this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_PREFIX");      libpath += name;      libpath += this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_SUFFIX");      }    else if (libType && std::string(libType) == "MODULE")      {      libpath += this->GetSafeDefinition("CMAKE_SHARED_MODULE_PREFIX");      libpath += name;      libpath += this->GetSafeDefinition("CMAKE_SHARED_MODULE_SUFFIX");      }    else if (libType && std::string(libType) == "STATIC")      {      libpath += this->GetSafeDefinition("CMAKE_STATIC_LIBRARY_PREFIX");      libpath += name;      libpath += this->GetSafeDefinition("CMAKE_STATIC_LIBRARY_SUFFIX");      }    fout << cmSystemTools::ConvertToOutputPath(libpath.c_str()) << " ";    }}void cmLocalUnixMakefileGenerator::OutputExeDepend(std::ostream& fout,                                              const char* name){  std::string exePath = name;  exePath += "_CMAKE_PATH";  const char* cacheValue = m_Makefile->GetDefinition(exePath.c_str());  if(cacheValue )    {    // if there is a cache value, then this is a executable/utility that cmake    // knows how to build, so we can depend on it    std::string exepath;    if (!this->SamePath(m_Makefile->GetCurrentOutputDirectory(), cacheValue))      {      // if the exe/utility is not in the current directory, then get the full      // path to it      if(m_ExecutableOutputPath.size())        {        exepath = m_ExecutableOutputPath;        }      else        {        exepath = cacheValue;        exepath += "/";        }      }    else      {      // library is in current Makefile      exepath = m_ExecutableOutputPath;      }    // add the library name    exepath += name;    // add the correct extension    exepath += cmSystemTools::GetExecutableExtension();    fout << cmSystemTools::ConvertToOutputPath(exepath.c_str()) << " ";    }}// fix up names of directories so they can be used// as targets in makefiles.inline std::string FixDirectoryName(const char* dir){  std::string s = dir;  // replace ../ with 3 under bars  size_t pos = s.find("../");  if(pos != std::string::npos)    {    s.replace(pos, 3, "___");    }  // replace / directory separators with a single under bar   pos = s.find("/");  while(pos != std::string::npos)    {    s.replace(pos, 1, "_");    pos = s.find("/");    }  return s;}void cmLocalUnixMakefileGenerator::BuildInSubDirectoryWindows(std::ostream& fout,                                                              const char* directory,                                                              const char* target1,                                                              const char* target2,                                                              bool silent){  if(target1)    {    std::string dir = this->ConvertToOutputForExisting(directory);    if(dir[0] == '\"')      {      dir = dir.substr(1, dir.size()-2);      }    fout << "\tif not exist \"" << dir << "\\$(NULL)\""         << " "          << "$(MAKE) $(MAKESILENT) rebuild_cache\n";    if (!silent)       {      fout << "\techo " << directory << ": building " << target1 << "\n";      }    fout << "\tcd " << dir << "\n"         << "\t$(MAKE) -$(MAKEFLAGS) $(MAKESILENT) " << target1 << "\n";    }  if(target2)    {    if (!silent)       {      fout << "\techo " << directory << ": building " << target2 << "\n";      }    fout << "\t$(MAKE) -$(MAKEFLAGS) $(MAKESILENT) " << target2 << "\n";    }  std::string currentDir = m_Makefile->GetCurrentOutputDirectory();  fout << "\tcd " << this->ConvertToOutputForExisting(currentDir.c_str()) << "\n\n";}void cmLocalUnixMakefileGenerator::BuildInSubDirectory(std::ostream& fout,                                                  const char* dir,                                                  const char* target1,                                                  const char* target2,                                                  bool silent){  if(m_WindowsShell)    {    this->BuildInSubDirectoryWindows(fout, dir, target1, target2, silent);    return;    }    std::string directory = cmSystemTools::ConvertToOutputPath(dir);  if(target1)    {    fout << "\t@if test ! -d " << directory          << "; then $(MAKE) rebuild_cache; fi\n";    if (!silent)       {      fout << "\techo " << directory << ": building " << target1 << "\n";      }    fout << "\t@cd " << directory         << "; $(MAKE) " << target1 << "\n";    }  if(target2)    {    if (!silent)       {      fout << "\techo " << directory << ": building " << target2 << "\n";      }    fout << "\t@cd " << directory         << "; $(MAKE) " << target2 << "\n";    }  fout << "\n";}void cmLocalUnixMakefileGenerator::OutputSubDirectoryVars(std::ostream& fout,                       const char* var,                       const char* target,                       const char* target1,                       const char* target2,                       const char* depend,                       const std::vector<std::string>& SubDirectories,                       bool silent){  if(!depend)    {    depend = "";    }  if( SubDirectories.size() == 0)    {    return;    }  fout << "# Variable for making " << target << " in subdirectories.\n";  fout << var << " = \\\n";  unsigned int ii;  for(ii =0; ii < SubDirectories.size(); ii++)    {     std::string subdir = FixDirectoryName(SubDirectories[ii].c_str());    fout << target << "_" << subdir.c_str();    if(ii == SubDirectories.size()-1)      {      fout << " \n\n";      }    else      {      fout << " \\\n";      }    }  fout << "# Targets for making " << target << " in subdirectories.\n";  std::string last = "";  for(unsigned int cc =0; cc < SubDirectories.size(); cc++)    {    std::string subdir = FixDirectoryName(SubDirectories[cc].c_str());    fout << target << "_" << subdir.c_str() << ": " << depend;        // Make each subdirectory depend on previous one.  This forces    // parallel builds (make -j 2) to build in same order as a single    // threaded build to avoid dependency problems.    if(cc > 0)      {      fout << " " << target << "_" << last.c_str();      }        fout << "\n";    last = subdir;    std::string dir = m_Makefile->GetCurrentOutputDirectory();    dir += "/";    dir += SubDirectories[cc];    this->BuildInSubDirectory(fout, dir.c_str(),                              target1, target2, silent);    }  fout << "\n\n";}// output rules for decending into sub directoriesvoid cmLocalUnixMakefileGenerator::OutputSubDirectoryRules(std::ostream& fout){    // Output Sub directory build rules  const std::vector<std::string>& SubDirectories    = m_Makefile->GetSubDirectories();      if( SubDirectories.size() == 0)    {    return;    }    this->OutputSubDirectoryVars(fout,                                "SUBDIR_BUILD",                               "default_target",                               "default_target",                               0, "$(TARGETS)",                               SubDirectories,                               false);  this->OutputSubDirectoryVars(fout, "SUBDIR_CLEAN", "clean",                               "clean",                               0, 0,                               SubDirectories);  this->OutputSubDirectoryVars(fout, "SUBDIR_DEPEND", "depend",                               "depend",                               0, 0,                               SubDirectories);  this->OutputSubDirectoryVars(fout, "SUBDIR_INSTALL", "install",                               "install",                               0, 0,                               SubDirectories);}// Output the depend information for all the classes // in the makefile.  These would have been generated// by the class cmMakeDepend GenerateMakefilebool cmLocalUnixMakefileGenerator::OutputObjectDepends(std::ostream& fout){  bool ret = false;  // Iterate over every target.  std::map<cmStdString, cmTarget>& targets = m_Makefile->GetTargets();  for(std::map<cmStdString, cmTarget>::const_iterator target = targets.begin();       target != targets.end(); ++target)    {    // Iterate over every source for this target.    const std::vector<cmSourceFile*>& sources = target->second.GetSourceFiles();    for(std::vector<cmSourceFile*>::const_iterator source = sources.begin();         source != sources.end(); ++source)      {      if(!(*source)->GetPropertyAsBool("HEADER_FILE_ONLY"))        {        if(!(*source)->GetDepends().empty())          {          // Iterate through all the dependencies for this source.          for(std::vector<std::string>::const_iterator dep =                (*source)->GetDepends().begin();              dep != (*source)->GetDepends().end(); ++dep)            {            fout << (*source)->GetSourceName()                 << this->GetOutputExtension(                   (*source)->GetSourceExtension().c_str()) << " : "                 << cmSystemTools::ConvertToOutputPath(dep->c_str()) << "\n";            ret = true;            }          fout << "\n\n";          }        }      }    }  return ret;}// Output the depend information for all the classes // in the makefile.  These would have been generated// by the class cmMakeDepend GenerateMakefilevoid cmLocalUnixMakefileGenerator::OutputCheckDepends(std::ostream& fout){  std::set<std::string> emittedLowerPath;  std::set<std::string> emitted;  // Iterate over every target.  std::map<cmStdString, cmTarget>& targets = m_Makefile->GetTargets();  fout << "# Suppresses display of executed commands\n";  fout << ".SILENT:\n";  fout << "# disable some common implicit rules to speed things up\n";  fout << ".SUFFIXES:\n";  fout << ".SUFFIXES:.hpuxmakemusthaverule\n";  this->OutputMakeVariables(fout);  fout << "default:\n";  fout << "\t$(MAKE) $(MAKESILENT) -f cmake.check_depends all\n"       << "\t$(MAKE) $(MAKESILENT) -f cmake.check_depends cmake.depends\n\n";  for(std::map<cmStdString, cmTarget>::const_iterator target = targets.begin();       target != targets.end(); ++target)    {    // Iterate over every source for this target.    const std::vector<cmSourceFile*>& sources = target->second.GetSourceFiles();    for(std::vector<cmSourceFile*>::const_iterator source = sources.begin();         source != sources.end(); ++source)      {      if(!(*source)->GetPropertyAsBool("HEADER_FILE_ONLY"))        {        if(!(*source)->GetDepends().empty())          {          for(std::vector<std::string>::const_iterator dep =                (*source)->GetDepends().begin();              dep != (*source)->GetDepends().end(); ++dep)            {            std::string dependfile =               cmSystemTools::ConvertToOutputPath(cmSystemTools::CollapseFullPath(dep->c_str()).c_str());            // use the lower path function to create uniqe names            std::string lowerpath = this->LowerCasePath(dependfile.c_str());            if(emittedLowerPath.insert(lowerpath).second)              {              emitted.insert(dependfile);              fout << "all:: " << dependfile << "\n";              }            }          }        }      }    }  fout << "\n\n# if any of these files changes run make dependlocal\n";  std::set<std::string>::iterator i;  for(i = emitted.begin(); i != emitted.end(); ++i)    {    fout << "cmake.depends:: " << *i <<       "\n\t$(MAKE) $(MAKESILENT) dependlocal\n\n";    }  fout << "\n\n";  fout << "# if a .h file is removed then run make dependlocal\n\n";  for(std::set<std::string>::iterator it = emitted.begin();      it != emitted.end(); ++it)    {    fout << *it << ":\n"         << "\t$(MAKE) $(MAKESILENT) dependlocal\n\n";    }}// Output each custom rule in the following format:// output: source depends...//   (tab)   command...void cmLocalUnixMakefileGenerator::OutputCustomRules(std::ostream& fout){  // We may be modifying the source groups temporarily, so make a copy.  std::vector<cmSourceGroup> sourceGroups = m_Makefile->GetSourceGroups();    const cmTargets &tgts = m_Makefile->GetTargets();  for(cmTargets::const_iterator tgt = tgts.begin();       tgt != tgts.end(); ++tgt)    {    // add any custom rules to the source groups    for (std::vector<cmCustomCommand>::const_iterator cr =            tgt->second.GetCustomCommands().begin();          cr != tgt->second.GetCustomCommands().end(); ++cr)      {      // if the source for the custom command is the same name      // as the target, then to not create a rule in the makefile for      // the custom command, as the command will be fired when the other target       // is built.        if ( cr->GetSourceName().compare(tgt->first) !=0)        {        cmSourceGroup& sourceGroup =           m_Makefile->FindSourceGroup(cr->GetSourceName().c_str(),                                      sourceGroups);        cmCustomCommand cc(*cr);        cc.ExpandVariables(*m_Makefile);        sourceGroup.AddCustomCommand(cc);        }      }    }  // Loop through every source group.  for(std::vector<cmSourceGroup>::const_iterator sg =        sourceGroups.begin(); sg != sourceGroups.end(); ++sg)    {    const cmSourceGroup::BuildRules& buildRules = sg->GetBuildRules();    if(buildRules.empty())      { continue; }        std::string name = sg->GetName();    if(name != "")      {      fout << "# Start of source group \"" << name.c_str() << "\"\n";      }        // Loop through each source in the source group.    for(cmSourceGroup::BuildRules::const_iterator cc =          buildRules.begin(); cc != buildRules.end(); ++ cc)      {      std::string source = cc->first;      const cmSourceGroup::Commands& commands = cc->second.m_Commands;      // Loop through every command generating code from the current source.      for(cmSourceGroup::Commands::const_iterator c = commands.begin();          c != commands.end(); ++c)        {        // escape spaces and convert to native slashes path for        // the command        const char* comment = c->second.m_Comment.c_str();        std::string command = c->second.m_Command;        cmSystemTools::ReplaceString(command, "/./", "/");        command = cmSystemTools::ConvertToOutputPath(command.c_str());        command += " ";        // now add the arguments        command += c->second.m_Arguments;        const cmSourceGroup::CommandFiles& commandFiles = c->second;        // if the command has no outputs, then it is a utility command        // with no outputs        if(commandFiles.m_Outputs.size() == 0)          {          std::string depends;          // collect out all the dependencies for this rule.          for(std::set<std::string>::const_iterator d =                commandFiles.m_Depends.begin();              d != commandFiles.m_Depends.end(); ++d)            {             std::string dep = *d;            cmSystemTools::ReplaceString(dep, "/./", "/");            cmSystemTools::ReplaceString(dep, "/$(IntDir)/", "/");            dep = cmSystemTools::ConvertToOutputPath(dep.c_str());            depends += " ";            depends += dep;            }          // output rule          this->OutputMakeRule(fout,                               (*comment?comment:"Custom command"),                               source.c_str(),                               depends.c_str(),                               command.c_str());          }        // Write a rule for every output generated by this command.        for(std::set<std::string>::const_iterator output =              commandFiles.m_Outputs.begin();            output != commandFiles.m_Outputs.end(); ++output)          {          std::string src = cmSystemTools::ConvertToOutputPath(source.c_str());          std::string depends;          depends +=  src;          // Collect out all the dependencies for this rule.          for(std::set<std::string>::const_iterator d =                commandFiles.m_Depends.begin();              d != commandFiles.m_Depends.end(); ++d)            {            std::string dep = *d;            cmSystemTools::ReplaceString(dep, "/./", "/");            cmSystemTools::ReplaceString(dep, "/$(IntDir)/", "/");            dep = cmSystemTools::ConvertToOutputPath(dep.c_str());            depends += " ";            depends += dep;            }           // output rule          this->OutputMakeRule(fout,                               (*comment?comment:"Custom command"),                               output->c_str(),                               depends.c_str(),                               command.c_str());          }        }      }    if(name != "")      {      fout << "# End of source group \"" << name.c_str() << "\"\n\n";      }    }  }std::string cmLocalUnixMakefileGenerator::ConvertToOutputForExisting(const char* p){  std::string ret = cmSystemTools::ConvertToOutputPath(p);  // if there are spaces in the path, then get the short path version  // if there is one  if(ret.find(' ') != std::string::npos)    {    if(cmSystemTools::FileExists(p))      {      if(!cmSystemTools::GetShortPath(ret.c_str(), ret))        {        ret = p;        }      }    }  return ret;}void cmLocalUnixMakefileGenerator::OutputMakeVariables(std::ostream& fout){  const char* variables =     "# the standard shell for make\n"    "SHELL = /bin/sh\n"    "\n";  if(!m_WindowsShell)    {    fout << variables;    }  else    {    fout <<       "!IF \"$(OS)\" == \"Windows_NT\"\n"      "NULL=\n"      "!ELSE \n"      "NULL=nul\n"      "!ENDIF \n";    }  if(m_MakeSilentFlag.size())    {    fout << "MAKESILENT                             = " << m_MakeSilentFlag << "\n";    }    std::string cmakecommand = this->ConvertToOutputForExisting(    m_Makefile->GetDefinition("CMAKE_COMMAND"));  fout << "CMAKE_COMMAND = "       << cmakecommand       << "\n";  fout << "RM = " << cmakecommand.c_str() << " -E remove -f\n";   if(m_Makefile->GetDefinition("CMAKE_EDIT_COMMAND"))    {    fout << "CMAKE_EDIT_COMMAND = "         << this->ConvertToOutputForExisting(m_Makefile->GetDefinition("CMAKE_EDIT_COMMAND"))         << "\n";    }  fout << "CMAKE_CURRENT_SOURCE = " <<     cmSystemTools::ConvertToOutputPath(m_Makefile->GetStartDirectory())        << "\n";  fout << "CMAKE_CURRENT_BINARY = " <<     cmSystemTools::ConvertToOutputPath(m_Makefile->GetStartOutputDirectory())       << "\n";  fout << "CMAKE_SOURCE_DIR = " <<     cmSystemTools::ConvertToOutputPath(m_Makefile->GetHomeDirectory())       << "\n";  fout << "CMAKE_BINARY_DIR = " <<     cmSystemTools::ConvertToOutputPath(m_Makefile->GetHomeOutputDirectory())       << "\n";  // Output Include paths  fout << "INCLUDE_FLAGS = ";  std::vector<std::string>& includes = m_Makefile->GetIncludeDirectories();  std::vector<std::string>::iterator i;  fout << "-I" <<     this->ConvertToOutputForExisting(m_Makefile->GetStartDirectory()) << " ";  for(i = includes.begin(); i != includes.end(); ++i)    {    std::string include = *i;    // Don't output a -I for the standard include path "/usr/include".    // This can cause problems with certain standard library    // implementations because the wrong headers may be found first.    if(include != "/usr/include")      {      fout << "-I" << this->ConvertToOutputForExisting(i->c_str()) << " ";      }    }  fout << m_Makefile->GetDefineFlags();  fout << "\n\n";}void cmLocalUnixMakefileGenerator::OutputInstallRules(std::ostream& fout){  const char* root    = m_Makefile->GetDefinition("CMAKE_ROOT");  fout << "INSTALL = " << root << "/Templates/install-sh -c\n";  fout << "INSTALL_PROGRAM = $(INSTALL)\n";  fout << "INSTALL_DATA =    $(INSTALL) -m 644\n";    const cmTargets &tgts = m_Makefile->GetTargets();  fout << "install: $(SUBDIR_INSTALL)\n";  fout << "\t@echo \"Installing ...\"\n";    const char* prefix    = m_Makefile->GetDefinition("CMAKE_INSTALL_PREFIX");  if (!prefix)    {    prefix = "/usr/local";    }  for(cmTargets::const_iterator l = tgts.begin();       l != tgts.end(); l++)    {    if (l->second.GetInstallPath() != "")      {      // first make the directories for each target       fout << "\t@if [ ! -d \"$(DESTDIR)" << prefix << l->second.GetInstallPath() <<         "\" ] ; then \\\n";      fout << "\t   echo \"Making directory \\\"$(DESTDIR)" << prefix            << l->second.GetInstallPath() << "\\\" \"; \\\n";      fout << "\t   mkdir -p \"$(DESTDIR)" << prefix << l->second.GetInstallPath()            << "\"; \\\n";      fout << "\t   chmod 755 \"$(DESTDIR)" <<  prefix << l->second.GetInstallPath()            << "\"; \\\n";      fout << "\t else true; \\\n";      fout << "\t fi\n";      std::string fname;      // now install the target      switch (l->second.GetType())        {        case cmTarget::STATIC_LIBRARY:        case cmTarget::SHARED_LIBRARY:        case cmTarget::MODULE_LIBRARY:          fname = m_LibraryOutputPath;          fname += this->GetFullTargetName(l->first.c_str(), l->second);          fout << "\t$(INSTALL_DATA) " << cmSystemTools::ConvertToOutputPath(fname.c_str())               << " \"$(DESTDIR)" << prefix << l->second.GetInstallPath() << "\"\n";          break;        case cmTarget::WIN32_EXECUTABLE:        case cmTarget::EXECUTABLE:          fname = m_ExecutableOutputPath;          fname += this->GetFullTargetName(l->first.c_str(), l->second);          fout << "\t$(INSTALL_PROGRAM) " << cmSystemTools::ConvertToOutputPath(fname.c_str())               << " \"$(DESTDIR)" << prefix << l->second.GetInstallPath() << "\"\n";          break;        case cmTarget::INSTALL_FILES:          {          std::string sourcePath = m_Makefile->GetCurrentDirectory();          std::string binaryPath = m_Makefile->GetCurrentOutputDirectory();          sourcePath += "/";          binaryPath += "/";          const std::vector<std::string> &sf = l->second.GetSourceLists();          std::vector<std::string>::const_iterator i;          for (i = sf.begin(); i != sf.end(); ++i)            {            std::string f = *i;            if(f.substr(0, sourcePath.length()) == sourcePath)              {              f = f.substr(sourcePath.length());              }            else if(f.substr(0, binaryPath.length()) == binaryPath)              {              f = f.substr(binaryPath.length());              }            fout << "\t@echo \"Installing " << f.c_str() << " \"\n";             // avoid using install-sh to install install-sh            // does not work on windows....             if(*i == "install-sh")              {              fout << "\t   @cp ";              }            else              {              fout << "\t   @$(INSTALL_DATA) ";              }                        fout << cmSystemTools::ConvertToOutputPath(i->c_str())                 << " \"$(DESTDIR)" << prefix << l->second.GetInstallPath() << "\"\n";            }          }          break;        case cmTarget::INSTALL_PROGRAMS:          {          std::string sourcePath = m_Makefile->GetCurrentDirectory();          std::string binaryPath = m_Makefile->GetCurrentOutputDirectory();          sourcePath += "/";          binaryPath += "/";          const std::vector<std::string> &sf = l->second.GetSourceLists();          std::vector<std::string>::const_iterator i;          for (i = sf.begin(); i != sf.end(); ++i)            {            std::string f = *i;            if(f.substr(0, sourcePath.length()) == sourcePath)              {              f = f.substr(sourcePath.length());              }            else if(f.substr(0, binaryPath.length()) == binaryPath)              {              f = f.substr(binaryPath.length());              }            fout << "\t@echo \"Installing " << f.c_str() << " \"\n";             // avoid using install-sh to install install-sh            // does not work on windows....             if(*i == "install-sh")              {              fout << "\t   @cp ";              }            else              {              fout << "\t   @$(INSTALL_PROGRAM) ";              }            fout << cmSystemTools::ConvertToOutputPath(i->c_str())                 << " \"$(DESTDIR)" << prefix << l->second.GetInstallPath() << "\"\n";            }          }          break;        case cmTarget::UTILITY:        default:          break;        }      }    }}void cmLocalUnixMakefileGenerator::OutputMakeRules(std::ostream& fout){  this->OutputMakeRule(fout,                        "default build rule",                       "all",                       "cmake.depends $(TARGETS) $(SUBDIR_BUILD)",                       0);  this->OutputMakeRule(fout,                        "clean generated files",                       "clean",                       "$(SUBDIR_CLEAN)",                       "-@ $(RM) $(CLEAN_OBJECT_FILES) "                       " $(TARGETS) $(GENERATED_QT_FILES) $(GENERATED_FLTK_FILES)");  // collect up all the sources  std::string allsources;  std::map<cmStdString, cmTarget>& targets = m_Makefile->GetTargets();  for(std::map<cmStdString, cmTarget>::const_iterator target = targets.begin();       target != targets.end(); ++target)    {    // Iterate over every source for this target.    const std::vector<cmSourceFile*>& sources = target->second.GetSourceFiles();    for(std::vector<cmSourceFile*>::const_iterator source = sources.begin();         source != sources.end(); ++source)      {      if(!(*source)->GetPropertyAsBool("HEADER_FILE_ONLY"))        {          allsources += " \\\n";          allsources += cmSystemTools::ConvertToOutputPath((*source)->GetFullPath().c_str());        }      }    }  this->OutputMakeRule(fout,                        "dependencies.",                       "cmake.depends",                       "$(CMAKE_MAKEFILE_SOURCES)",                       "$(CMAKE_COMMAND) "                       "-S$(CMAKE_CURRENT_SOURCE) -O$(CMAKE_CURRENT_BINARY) "                       "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)"    );  this->OutputMakeRule(fout,                        "dependencies",                       "cmake.check_depends",                       allsources.c_str(),                       "$(CMAKE_COMMAND) "                       "-S$(CMAKE_CURRENT_SOURCE) -O$(CMAKE_CURRENT_BINARY) "                       "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)"    );    this->OutputMakeRule(fout,                        "dependencies",                       "depend",                       "$(SUBDIR_DEPEND)",                       "$(CMAKE_COMMAND) "                       "-S$(CMAKE_CURRENT_SOURCE) -O$(CMAKE_CURRENT_BINARY) "                       "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)");    this->OutputMakeRule(fout,                        "dependencies",                       "dependlocal",                       0,                       "$(CMAKE_COMMAND) "                       "-S$(CMAKE_CURRENT_SOURCE) -O$(CMAKE_CURRENT_BINARY) "                       "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)");    this->OutputMakeRule(fout,                        "CMakeCache.txt",                       "rebuild_cache",                       "$(CMAKE_BINARY_DIR)/CMakeCache.txt",                       "$(CMAKE_COMMAND) "                       "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)");    std::string checkCache = m_Makefile->GetHomeOutputDirectory();  checkCache += "/cmake.check_cache";  checkCache = cmSystemTools::ConvertToOutputPath(checkCache.c_str());  std::string CMakeCache = m_Makefile->GetHomeOutputDirectory();  CMakeCache += "/CMakeCache.txt";  CMakeCache = cmSystemTools::ConvertToOutputPath(CMakeCache.c_str());  this->OutputMakeRule(fout,                        "CMakeCache.txt because out-of-date:",                       checkCache.c_str(),                       CMakeCache.c_str(),                       "$(CMAKE_COMMAND) "                       "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)");  // if CMAKE_EDIT_COMMAND is defined then add a rule to run it  // called edit_cache  if(m_Makefile->GetDefinition("CMAKE_EDIT_COMMAND"))    {    this->OutputMakeRule(fout,                          "edit CMakeCache.txt",                         "edit_cache",                         0,                         "$(CMAKE_EDIT_COMMAND) "                         "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)");    }    this->OutputMakeRule(fout,                        "CMakeCache.txt",                       "$(CMAKE_BINARY_DIR)/CMakeCache.txt",                       0,                       "$(CMAKE_COMMAND) "                       "-H$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)");  this->OutputMakeRule(fout,                        "Rule to keep make from removing Makefiles "                       "if control-C is hit during a run of cmake.",                       ".PRECIOUS",                       "Makefile cmake.depends",                       0);    this->OutputSourceObjectBuildRules(fout);  // find ctest  std::string ctest = m_Makefile->GetDefinition("CMAKE_COMMAND");  ctest = cmSystemTools::GetFilenamePath(ctest.c_str());  ctest += "/";  ctest += "ctest";  ctest += cmSystemTools::GetExecutableExtension();  if(!cmSystemTools::FileExists(ctest.c_str()))    {    ctest = m_Makefile->GetDefinition("CMAKE_COMMAND");    ctest = cmSystemTools::GetFilenamePath(ctest.c_str());    ctest += "/Debug/";    ctest += "ctest";    ctest += cmSystemTools::GetExecutableExtension();    }  if(!cmSystemTools::FileExists(ctest.c_str()))    {    ctest = m_Makefile->GetDefinition("CMAKE_COMMAND");    ctest = cmSystemTools::GetFilenamePath(ctest.c_str());    ctest += "/Release/";    ctest += "ctest";    ctest += cmSystemTools::GetExecutableExtension();    }  if (cmSystemTools::FileExists(ctest.c_str()))    {    fout << "ARGS=\n";    std::string cmd = this->ConvertToOutputForExisting(ctest.c_str());    cmd += " $(ARGS)";    this->OutputMakeRule(fout,                          "tests",                         "test",                         "",                         cmd.c_str());    }}void cmLocalUnixMakefileGenerator::OutputBuildObjectFromSource(std::ostream& fout,                            const char* shortName,                            const cmSourceFile& source,                            const char* extraCompileFlags,                            bool shared){  // Header files shouldn't have build rules.  if(source.GetPropertyAsBool("HEADER_FILE_ONLY"))    {    return;    }  std::string comment = "object file";  std::string objectFile = std::string(shortName) +     this->GetOutputExtension(source.GetSourceExtension().c_str());  objectFile = cmSystemTools::ConvertToOutputPath(objectFile.c_str());  cmSystemTools::FileFormat format =     cmSystemTools::GetFileFormat(source.GetSourceExtension().c_str());  std::vector<std::string> rules;  std::string flags;  if(extraCompileFlags)    {    flags += extraCompileFlags;    }  std::string sourceFile =     cmSystemTools::ConvertToOutputPath(source.GetFullPath().c_str());   std::string buildType =  this->GetSafeDefinition("CMAKE_BUILD_TYPE");  buildType = cmSystemTools::UpperCase(buildType);  switch(format)    {    case cmSystemTools::C_FILE_FORMAT:      {      rules.push_back(m_Makefile->GetDefinition("CMAKE_C_COMPILE_OBJECT"));      flags += this->GetSafeDefinition("CMAKE_C_FLAGS");      flags += " ";      if(buildType.size())        {        std::string build = "CMAKE_C_FLAGS_";        build += buildType;        flags +=  this->GetSafeDefinition(build.c_str());        flags += " ";        }      if(shared)        {        flags += this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_C_FLAGS");        flags += " ";        }        if(cmSystemTools::IsOn(m_Makefile->GetDefinition("BUILD_SHARED_LIBS")))        {        flags += this->GetSafeDefinition("CMAKE_SHARED_BUILD_C_FLAGS");        flags += " ";        }      break;      }    case cmSystemTools::CXX_FILE_FORMAT:      {      rules.push_back(m_Makefile->GetDefinition("CMAKE_CXX_COMPILE_OBJECT"));      flags += this->GetSafeDefinition("CMAKE_CXX_FLAGS");      flags += " ";       if(buildType.size())        {        std::string build = "CMAKE_CXX_FLAGS_";        build += buildType;        flags +=  this->GetSafeDefinition(build.c_str());        flags += " ";        }      if(shared)        {        flags += this->GetSafeDefinition("CMAKE_SHARED_LIBRARY_CXX_FLAGS");        flags += " ";        }      if(cmSystemTools::IsOn(m_Makefile->GetDefinition("BUILD_SHARED_LIBS")))        {        flags += this->GetSafeDefinition("CMAKE_SHARED_BUILD_CXX_FLAGS");        flags += " ";        }      break;      }    case cmSystemTools::HEADER_FILE_FORMAT:      return;    case cmSystemTools::DEFINITION_FILE_FORMAT:      return;    case cmSystemTools::RESOURCE_FILE_FORMAT:      {      flags = " $(INCLUDE_FLAGS) ";      // use rc rule here if it is defined      const char* rule = m_Makefile->GetDefinition("CMAKE_COMPILE_RESOURCE");      if(rule)        {        rules.push_back(rule);        }      }      break;    case cmSystemTools::NO_FILE_FORMAT:    case cmSystemTools::JAVA_FILE_FORMAT:    case cmSystemTools::STATIC_LIBRARY_FILE_FORMAT:    case cmSystemTools::SHARED_LIBRARY_FILE_FORMAT:    case cmSystemTools::MODULE_FILE_FORMAT:    case cmSystemTools::OBJECT_FILE_FORMAT:    case cmSystemTools::UNKNOWN_FILE_FORMAT:      cmSystemTools::Error("Unexpected file type ",                           sourceFile.c_str());      break;    }   flags += "$(INCLUDE_FLAGS) ";  // expand multi-command semi-colon separated lists  // of commands into separate commands  std::vector<std::string> commands;  cmSystemTools::ExpandList(rules, commands);  for(std::vector<std::string>::iterator i = commands.begin();      i != commands.end(); ++i)    {    this->ExpandRuleVariables(*i,                              0, // no objects                              0, // no target                              0, // no link libs                              sourceFile.c_str(),                              objectFile.c_str(),                              flags.c_str());    }    std::vector<std::string> sourceAndDeps;  sourceAndDeps.push_back(sourceFile);    // Check for extra object-file dependencies.  std::vector<std::string> depends;  const char* additionalDeps = source.GetProperty("OBJECT_DEPENDS");  if(additionalDeps)    {    cmSystemTools::ExpandListArgument(additionalDeps, depends);    for(std::vector<std::string>::iterator i = depends.begin();        i != depends.end(); ++i)      {      sourceAndDeps.push_back(cmSystemTools::ConvertToOutputPath(i->c_str()));      }    }    this->OutputMakeRule(fout,                       comment.c_str(),                       objectFile.c_str(),                       sourceAndDeps,                       commands);}void cmLocalUnixMakefileGenerator::OutputSourceObjectBuildRules(std::ostream& fout){  fout << "# Rules to build " << this->GetOutputExtension("")       << " files from their sources:\n";  std::set<std::string> rules;    // Iterate over every target.  std::map<cmStdString, cmTarget>& targets = m_Makefile->GetTargets();  for(std::map<cmStdString, cmTarget>::const_iterator target = targets.begin();       target != targets.end(); ++target)    {    bool shared = ((target->second.GetType() == cmTarget::SHARED_LIBRARY) ||                   (target->second.GetType() == cmTarget::MODULE_LIBRARY));    std::string exportsDef = "";    if(shared)      {      std::string export_symbol;      if (const char* custom_export_name = target->second.GetProperty("DEFINE_SYMBOL"))        {        export_symbol = custom_export_name;        }      else        {        std::string in = target->first + "_EXPORTS";        export_symbol = cmSystemTools::MakeCindentifier(in.c_str());        }          exportsDef = "-D"+ export_symbol;      }    // Iterate over every source for this target.    const std::vector<cmSourceFile*>& sources = target->second.GetSourceFiles();    for(std::vector<cmSourceFile*>::const_iterator source = sources.begin();         source != sources.end(); ++source)      {      if(!(*source)->GetPropertyAsBool("HEADER_FILE_ONLY"))        {        std::string shortName;        std::string sourceName;        // If the full path to the source file includes this        // directory, we want to use the relative path for the        // filename of the object file.  Otherwise, we will use just        // the filename portion.        if((cmSystemTools::GetFilenamePath((*source)->GetFullPath()).find(m_Makefile->GetCurrentDirectory()) == 0)           || (cmSystemTools::GetFilenamePath((*source)->GetFullPath()).find(m_Makefile->                                                                          GetCurrentOutputDirectory()) == 0))          {          sourceName = (*source)->GetSourceName()+"."+(*source)->GetSourceExtension();          shortName = (*source)->GetSourceName();                    // The path may be relative.  See if a directory needs to be          // created for the output file.  This is a ugly, and perhaps          // should be moved elsewhere.          std::string relPath =            cmSystemTools::GetFilenamePath((*source)->GetSourceName());          if(relPath != "")            {            std::string outPath = m_Makefile->GetCurrentOutputDirectory();            outPath += "/"+relPath;            cmSystemTools::MakeDirectory(outPath.c_str());            }          }        else          {          sourceName = (*source)->GetFullPath();          shortName = cmSystemTools::GetFilenameName((*source)->GetSourceName());          }        std::string shortNameWithExt = shortName +          (*source)->GetSourceExtension();        // Only output a rule for each .o once.        std::string compileFlags = exportsDef;        compileFlags += " ";        if(rules.find(shortNameWithExt) == rules.end())          {                    if((*source)->GetProperty("COMPILE_FLAGS"))            {            compileFlags += (*source)->GetProperty("COMPILE_FLAGS");            compileFlags += " ";            }          this->OutputBuildObjectFromSource(fout,                                            shortName.c_str(),                                            *(*source),                                            compileFlags.c_str(),                                            shared);          rules.insert(shortNameWithExt);          }        }      }    }}void cmLocalUnixMakefileGenerator::OutputMakeRule(std::ostream& fout,                                                   const char* comment,                                                  const char* target,                                                  const char* depends,                                                   const char* command,                                                  const char* command2,                                                  const char* command3,                                                  const char* command4){  std::vector<std::string> commands;  if(command)    {    commands.push_back(command);    }  if(command2)    {    commands.push_back(command2);    }  if(command3)    {    commands.push_back(command3);    }  if(command4)    {    commands.push_back(command4);    }  this->OutputMakeRule(fout, comment, target, depends, commands);}void cmLocalUnixMakefileGenerator::OutputMakeRule(std::ostream& fout,                                                   const char* comment,                                                  const char* target,                                                  const char* depends,                                                   const std::vector<std::string>& commands){  std::vector<std::string> depend;  if(depends)    {    depend.push_back(depends);    }  this->OutputMakeRule(fout, comment, target, depend, commands);}void cmLocalUnixMakefileGenerator::OutputMakeRule(std::ostream& fout,                                                   const char* comment,                                                  const char* target,                                                  const std::vector<std::string>& depends,                                                  const std::vector<std::string>& commands){  if(!target)    {    cmSystemTools::Error("no target for OutputMakeRule");    return;    }    std::string replace;  if(comment)    {    replace = comment;    m_Makefile->ExpandVariablesInString(replace);    fout << "#---------------------------------------------------------\n";    fout << "# " << replace;    fout << "\n#\n";    }  fout << "\n";  replace = target;  m_Makefile->ExpandVariablesInString(replace);  fout << cmSystemTools::ConvertToOutputPath(replace.c_str()) << ":";  for(std::vector<std::string>::const_iterator dep = depends.begin();      dep != depends.end(); ++dep)    {    replace = *dep;    m_Makefile->ExpandVariablesInString(replace);    fout << " " << replace.c_str();    }  fout << "\n";  int count = 0;  for (std::vector<std::string>::const_iterator i = commands.begin();       i != commands.end(); ++i)     {    replace = *i;    m_Makefile->ExpandVariablesInString(replace);    if(count == 0 && replace.find_first_not_of(" \t\n\r") != std::string::npos &&        replace[0] != '-' && replace.find("echo") != 0         && replace.find("$(MAKE)") != 0)      {      std::string echostring = "Building ";      echostring += comment;      echostring += " ";      echostring += target;      echostring += "...";            // for unix we want to quote the output of echo      // for nmake and borland, the echo should not be quoted      if(strcmp(m_GlobalGenerator->GetName(), "Unix Makefiles") == 0)        {        cmSystemTools::ReplaceString(echostring, "\\\n", " ");        cmSystemTools::ReplaceString(echostring, " \t", "   ");        cmSystemTools::ReplaceString(echostring, "\n\t", "\"\n\techo \"");        fout << "\techo \"" << echostring.c_str() << "\"\n";        }      else        {        cmSystemTools::ReplaceString(echostring, "\n\t", "\n\techo ");        fout << "\techo " << echostring.c_str() << "\n";        }      }    fout << "\t" << replace.c_str() << "\n";    count++;    }  fout << "\n";}const char* cmLocalUnixMakefileGenerator::GetSafeDefinition(const char* def){  const char* ret = m_Makefile->GetDefinition(def);  if(!ret)    {    return "";    }  return ret;}std::string cmLocalUnixMakefileGenerator::LowerCasePath(const char* path){#ifdef _WIN32   return cmSystemTools::LowerCase(path);#else   return std::string(path);#endif}  std::stringcmLocalUnixMakefileGenerator::CreateMakeVariable(const char* s, const char* s2){  if(!m_MakefileVariableSize)    {    return std::string(s) + std::string(s2);    }  std::string unmodified = s;  unmodified += s2;  // see if th  std::map<cmStdString, cmStdString>::iterator i = m_MakeVariableMap.find(unmodified);  if(i != m_MakeVariableMap.end())    {    return i->second;    }  std::string ret = unmodified;  // if the string is greater the 32 chars it is an invalid vairable name  // for borland make  if(static_cast<int>(ret.size()) > m_MakefileVariableSize)    {    int keep = m_MakefileVariableSize - 8;    int size = keep + 3;    std::string str1 = s;    std::string str2 = s2;    // we must shorten the combined string by 4 charactors    // keep no more than 24 charactors from the second string    if(static_cast<int>(str2.size()) > keep)      {      str2 = str2.substr(0, keep);      }    if(static_cast<int>(str1.size()) + static_cast<int>(str2.size()) > size)      {      str1 = str1.substr(0, size - str2.size());      }    char buffer[5];    int ni = 0;    sprintf(buffer, "%04d", ni);    ret = str1 + str2 + buffer;    while(m_ShortMakeVariableMap.count(ret) && ni < 1000)      {      ++ni;      sprintf(buffer, "%04d", ni);      ret = str1 + str2 + buffer;      }    if(ni == 1000)      {      cmSystemTools::Error("Borland makefile variable length too long");      return unmodified;      }    // once an unused variable is found     m_ShortMakeVariableMap[ret] = "1";    }  // always make an entry into the unmodified to variable map  m_MakeVariableMap[unmodified] = ret;  return ret;}
 |