| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841 | /*=========================================================================  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 "cmLocalVisualStudio6Generator.h"#include "cmMakefile.h"#include "cmSystemTools.h"#include "cmSourceFile.h"#include "cmCacheManager.h"cmLocalVisualStudio6Generator::cmLocalVisualStudio6Generator(){}cmLocalVisualStudio6Generator::~cmLocalVisualStudio6Generator(){}void cmLocalVisualStudio6Generator::Generate(bool /* fromTheTop */){  this->OutputDSPFile();}void cmLocalVisualStudio6Generator::OutputDSPFile(){   // If not an in source build, then create the output directory  if(strcmp(m_Makefile->GetStartOutputDirectory(),            m_Makefile->GetHomeDirectory()) != 0)    {    if(!cmSystemTools::MakeDirectory(m_Makefile->GetStartOutputDirectory()))      {      cmSystemTools::Error("Error creating directory ",                           m_Makefile->GetStartOutputDirectory());      }    }  // Setup /I and /LIBPATH options for the resulting DSP file  std::vector<std::string>& includes = m_Makefile->GetIncludeDirectories();  std::vector<std::string>::iterator i;  for(i = includes.begin(); i != includes.end(); ++i)    {    m_IncludeOptions +=  " /I ";    std::string tmp = cmSystemTools::ConvertToOutputPath(i->c_str());    // quote if not already quoted    if (tmp[0] != '"')      {      m_IncludeOptions += "\"";      m_IncludeOptions += tmp;      m_IncludeOptions += "\"";      }    else      {      m_IncludeOptions += tmp;      }    }    // Create the DSP or set of DSP's for libraries and executables  // clear project names  m_CreatedProjectNames.clear();  // build any targets  cmTargets &tgts = m_Makefile->GetTargets();  for(cmTargets::iterator l = tgts.begin();       l != tgts.end(); l++)    {    switch(l->second.GetType())      {      case cmTarget::STATIC_LIBRARY:        this->SetBuildType(STATIC_LIBRARY, l->first.c_str());        break;      case cmTarget::SHARED_LIBRARY:        this->SetBuildType(DLL, l->first.c_str());        break;      case cmTarget::EXECUTABLE:        this->SetBuildType(EXECUTABLE,l->first.c_str());        break;      case cmTarget::WIN32_EXECUTABLE:        this->SetBuildType(WIN32_EXECUTABLE,l->first.c_str());        break;      case cmTarget::UTILITY:        this->SetBuildType(UTILITY, l->first.c_str());        break;      case cmTarget::INSTALL_FILES:        break;      case cmTarget::INSTALL_PROGRAMS:        break;      default:        cmSystemTools::Error("Bad target type", l->first.c_str());        break;      }    // INCLUDE_EXTERNAL_MSPROJECT command only affects the workspace    // so don't build a projectfile for it    if ((l->second.GetType() != cmTarget::INSTALL_FILES)        && (l->second.GetType() != cmTarget::INSTALL_PROGRAMS)        && (strncmp(l->first.c_str(), "INCLUDE_EXTERNAL_MSPROJECT", 26) != 0))      {      // check to see if the dsp is going into a sub-directory      std::string::size_type pos = l->first.rfind('/');      if(pos != std::string::npos)        {        std::string dir = m_Makefile->GetStartOutputDirectory();        dir += "/";        dir += l->first.substr(0, pos);        if(!cmSystemTools::MakeDirectory(dir.c_str()))          {          cmSystemTools::Error("Error creating directory ", dir.c_str());          }        }      this->CreateSingleDSP(l->first.c_str(),l->second);      }    }}void cmLocalVisualStudio6Generator::CreateSingleDSP(const char *lname, cmTarget &target){  // add to the list of projects  std::string pname = lname;  m_CreatedProjectNames.push_back(pname);  // create the dsp.cmake file  std::string fname;  fname = m_Makefile->GetStartOutputDirectory();  fname += "/";  fname += lname;  fname += ".dsp";  // save the name of the real dsp file  std::string realDSP = fname;  fname += ".cmake";  std::ofstream fout(fname.c_str());  if(!fout)    {    cmSystemTools::Error("Error Writing ", fname.c_str());    }  this->WriteDSPFile(fout,lname,target);  fout.close();  // if the dsp file has changed, then write it.  cmSystemTools::CopyFileIfDifferent(fname.c_str(), realDSP.c_str());}void cmLocalVisualStudio6Generator::AddDSPBuildRule(cmSourceGroup& sourceGroup){  std::string dspname = *(m_CreatedProjectNames.end()-1);  if(dspname == "ALL_BUILD")  {    return;  }  dspname += ".dsp.cmake";  std::string makefileIn = m_Makefile->GetStartDirectory();  makefileIn += "/";  makefileIn += "CMakeLists.txt";  std::string makefileInNC = makefileIn;  makefileIn = cmSystemTools::ConvertToOutputPath(makefileIn.c_str());  std::string dsprule = "${CMAKE_COMMAND}";  m_Makefile->ExpandVariablesInString(dsprule);  std::string args = makefileIn;  args += " -H";  args +=    cmSystemTools::ConvertToOutputPath(m_Makefile->GetHomeDirectory());  args += " -S";  args +=    cmSystemTools::ConvertToOutputPath(m_Makefile->GetStartDirectory());  args += " -O";  args +=     cmSystemTools::ConvertToOutputPath(m_Makefile->GetStartOutputDirectory());  args += " -B";  args +=     cmSystemTools::ConvertToOutputPath(m_Makefile->GetHomeOutputDirectory());  m_Makefile->ExpandVariablesInString(args);  std::string configFile =     m_Makefile->GetDefinition("CMAKE_ROOT");  configFile += "/Templates/CMakeWindowsSystemConfig.cmake";  std::vector<std::string> listFiles = m_Makefile->GetListFiles();  bool found = false;  for(std::vector<std::string>::iterator i = listFiles.begin();      i != listFiles.end(); ++i)    {    if(*i == configFile)      {      found  = true;      }    }  if(!found)    {    listFiles.push_back(configFile);    }    std::vector<std::string> outputs;  outputs.push_back(dspname);  cmCustomCommand cc(makefileInNC.c_str(), dsprule.c_str(),                     args.c_str(),                     listFiles,                      outputs);  sourceGroup.AddCustomCommand(cc);}void cmLocalVisualStudio6Generator::WriteDSPFile(std::ostream& fout,                                  const char *libName,                                 cmTarget &target){  // We may be modifying the source groups temporarily, so make a copy.  std::vector<cmSourceGroup> sourceGroups = m_Makefile->GetSourceGroups();    // get the classes from the source lists then add them to the groups  std::vector<cmSourceFile*> classes = target.GetSourceFiles();  for(std::vector<cmSourceFile*>::iterator i = classes.begin();       i != classes.end(); i++)    {    // Add the file to the list of sources.    std::string source = (*i)->GetFullPath();    cmSourceGroup& sourceGroup = m_Makefile->FindSourceGroup(source.c_str(),                                                             sourceGroups);    sourceGroup.AddSource(source.c_str(), *i);    }    // add any custom rules to the source groups  for (std::vector<cmCustomCommand>::const_iterator cr =          target.GetCustomCommands().begin();        cr != target.GetCustomCommands().end(); ++cr)    {    cmSourceGroup& sourceGroup =       m_Makefile->FindSourceGroup(cr->GetSourceName().c_str(),                                  sourceGroups);    cmCustomCommand cc(*cr);    cc.ExpandVariables(*m_Makefile);    sourceGroup.AddCustomCommand(cc);    }    // Write the DSP file's header.  this->WriteDSPHeader(fout, libName, target, sourceGroups);    // Find the group in which the CMakeLists.txt source belongs, and add  // the rule to generate this DSP file.  for(std::vector<cmSourceGroup>::reverse_iterator sg = sourceGroups.rbegin();      sg != sourceGroups.rend(); ++sg)    {    if(sg->Matches("CMakeLists.txt"))      {      this->AddDSPBuildRule(*sg);      break;      }        }    // 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 the group is empty, don't write it at all.    if(buildRules.empty())      { continue; }        // If the group has a name, write the header.    std::string name = sg->GetName();    if(name != "")      {      this->WriteDSPBeginGroup(fout, name.c_str(), "");      }        // Loop through each build rule 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;      const char* compileFlags = 0;      if(cc->second.m_SourceFile)        {        compileFlags = cc->second.m_SourceFile->GetProperty("COMPILE_FLAGS");        }      if (source != libName || target.GetType() == cmTarget::UTILITY)        {        fout << "# Begin Source File\n\n";                // Tell MS-Dev what the source is.  If the compiler knows how to        // build it, then it will.        fout << "SOURCE=" <<           cmSystemTools::ConvertToOutputPath(source.c_str()) << "\n\n";        if (!commands.empty())          {          cmSourceGroup::CommandFiles totalCommand;          std::string totalCommandStr;          totalCommandStr = this->CombineCommands(commands, totalCommand,                                                  source.c_str());          this->WriteCustomRule(fout, source.c_str(), totalCommandStr.c_str(),                                 totalCommand.m_Depends,                                 totalCommand.m_Outputs, compileFlags);          }        else if(compileFlags)          {          for(std::vector<std::string>::iterator i                = m_Configurations.begin(); i != m_Configurations.end(); ++i)            {             if (i == m_Configurations.begin())              {              fout << "!IF  \"$(CFG)\" == " << i->c_str() << std::endl;              }            else               {              fout << "!ELSEIF  \"$(CFG)\" == " << i->c_str() << std::endl;              }            fout << "\n# ADD CPP " << compileFlags << "\n\n";            }           fout << "!ENDIF\n\n";          }        fout << "# End Source File\n";        }      }        // If the group has a name, write the footer.    if(name != "")      {      this->WriteDSPEndGroup(fout);      }    }    // Write the DSP file's footer.  this->WriteDSPFooter(fout);}void cmLocalVisualStudio6Generator::WriteCustomRule(std::ostream& fout,                                  const char* source,                                  const char* command,                                  const std::set<std::string>& depends,                                  const std::set<std::string>& outputs,                                  const char* flags                                  ){  std::vector<std::string>::iterator i;  for(i = m_Configurations.begin(); i != m_Configurations.end(); ++i)    {    if (i == m_Configurations.begin())      {      fout << "!IF  \"$(CFG)\" == " << i->c_str() << std::endl;      }    else       {      fout << "!ELSEIF  \"$(CFG)\" == " << i->c_str() << std::endl;      }    if(flags)      {      fout << "\n# ADD CPP " << flags << "\n\n";      }    // Write out the dependencies for the rule.    fout << "USERDEP__HACK=";    for(std::set<std::string>::const_iterator d = depends.begin();        d != depends.end(); ++d)      {      fout << "\\\n\t" <<         cmSystemTools::ConvertToOutputPath(d->c_str());      }    fout << "\n";    fout << "# PROP Ignore_Default_Tool 1\n";    fout << "# Begin Custom Build\n\n";    if(outputs.size() == 0)      {      fout << source << "_force :  \"$(SOURCE)\" \"$(INTDIR)\" \"$(OUTDIR)\"";      fout << command << "\n\n";      }        // Write a rule for every output generated by this command.    for(std::set<std::string>::const_iterator output = outputs.begin();        output != outputs.end(); ++output)      {      fout << "\"" << output->c_str()           << "\" :  \"$(SOURCE)\" \"$(INTDIR)\" \"$(OUTDIR)\"";      fout << command << "\n\n";      }        fout << "# End Custom Build\n\n";    }    fout << "!ENDIF\n\n";}void cmLocalVisualStudio6Generator::WriteDSPBeginGroup(std::ostream& fout,                                         const char* group,                                        const char* filter){  fout << "# Begin Group \"" << group << "\"\n"    "# PROP Default_Filter \"" << filter << "\"\n";}void cmLocalVisualStudio6Generator::WriteDSPEndGroup(std::ostream& fout){  fout << "# End Group\n";}void cmLocalVisualStudio6Generator::SetBuildType(BuildType b, const char *libName){  std::string root= m_Makefile->GetDefinition("CMAKE_ROOT");  const char *def= m_Makefile->GetDefinition( "MSPROJECT_TEMPLATE_DIRECTORY");  if( def)    {    root = def;    }  else    {    root += "/Templates";    }    switch(b)    {    case STATIC_LIBRARY:      m_DSPHeaderTemplate = root;      m_DSPHeaderTemplate += "/staticLibHeader.dsptemplate";      m_DSPFooterTemplate = root;      m_DSPFooterTemplate += "/staticLibFooter.dsptemplate";      break;    case DLL:      m_DSPHeaderTemplate =  root;      m_DSPHeaderTemplate += "/DLLHeader.dsptemplate";      m_DSPFooterTemplate =  root;      m_DSPFooterTemplate += "/DLLFooter.dsptemplate";      break;    case EXECUTABLE:      m_DSPHeaderTemplate = root;      m_DSPHeaderTemplate += "/EXEHeader.dsptemplate";      m_DSPFooterTemplate = root;      m_DSPFooterTemplate += "/EXEFooter.dsptemplate";      break;    case WIN32_EXECUTABLE:      m_DSPHeaderTemplate = root;      m_DSPHeaderTemplate += "/EXEWinHeader.dsptemplate";      m_DSPFooterTemplate = root;      m_DSPFooterTemplate += "/EXEFooter.dsptemplate";      break;    case UTILITY:      m_DSPHeaderTemplate = root;      m_DSPHeaderTemplate += "/UtilityHeader.dsptemplate";      m_DSPFooterTemplate = root;      m_DSPFooterTemplate += "/UtilityFooter.dsptemplate";      break;    }  // once the build type is set, determine what configurations are  // possible  std::ifstream fin(m_DSPHeaderTemplate.c_str());  cmRegularExpression reg("# Name ");  if(!fin)    {    cmSystemTools::Error("Error Reading ", m_DSPHeaderTemplate.c_str());    }  // reset m_Configurations  m_Configurations.erase(m_Configurations.begin(), m_Configurations.end());  // now add all the configurations possible  char buffer[2048];  while(fin)    {    fin.getline(buffer, 2048);    std::string line = buffer;    cmSystemTools::ReplaceString(line, "OUTPUT_LIBNAME",libName);    if (reg.find(line))      {      m_Configurations.push_back(line.substr(reg.end()));      }    }}std::stringcmLocalVisualStudio6Generator::CombineCommands(const cmSourceGroup::Commands &commands,                             cmSourceGroup::CommandFiles &totalCommand,                             const char *source)  {  // Loop through every custom command generating code from the  // current source.  // build up the depends and outputs and commands   std::string totalCommandStr = "";  std::string temp;  for(cmSourceGroup::Commands::const_iterator c = commands.begin();      c != commands.end(); ++c)    {    totalCommandStr += "\n\t";    temp= c->second.m_Command;     temp = cmSystemTools::ConvertToOutputPath(temp.c_str());    totalCommandStr += temp;    totalCommandStr += " ";    totalCommandStr += c->second.m_Arguments;    totalCommand.Merge(c->second);    }        // Create a dummy file with the name of the source if it does  // not exist  if(totalCommand.m_Outputs.empty())    {     std::string dummyFile = m_Makefile->GetStartOutputDirectory();    dummyFile += "/";    dummyFile += source;    if(!cmSystemTools::FileExists(dummyFile.c_str()))      {      std::ofstream fout(dummyFile.c_str());      fout << "Dummy file created by cmake as unused source for utility command.\n";      }    }  return totalCommandStr;}// look for custom rules on a target and collect them togetherstd::string cmLocalVisualStudio6Generator::CreateTargetRules(const cmTarget &target,                                const char *libName){  std::string customRuleCode = "";  if (target.GetType() >= cmTarget::UTILITY)    {    return customRuleCode;    }    // Find the group in which the lix exe custom rules belong  bool init = 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() == libName)      {      if (!init)        {        // header stuff        customRuleCode = "# Begin Special Build Tool\nPostBuild_Cmds=";        init = true;        }      else        {        customRuleCode += "\t";        }      customRuleCode += cc.GetCommand() + " " + cc.GetArguments();      }    }  if (init)    {    customRuleCode += "\n# End Special Build Tool\n";    }  return customRuleCode;}inline std::string removeQuotes(const std::string& s){  if(s[0] == '\"' && s[s.size()-1] == '\"')    {    return s.substr(1, s.size()-2);    }  return s;}  void cmLocalVisualStudio6Generator::WriteDSPHeader(std::ostream& fout, const char *libName,                                   const cmTarget &target,                                  std::vector<cmSourceGroup> &){  std::set<std::string> pathEmitted;    // determine the link directories  std::string libOptions;  std::string libDebugOptions;  std::string libOptimizedOptions;  std::string libMultiLineOptions;  std::string libMultiLineDebugOptions;  std::string libMultiLineOptimizedOptions;  // suppoirt override in output directory  std::string libPath = "";  if (m_Makefile->GetDefinition("LIBRARY_OUTPUT_PATH"))    {    libPath = m_Makefile->GetDefinition("LIBRARY_OUTPUT_PATH");    }  std::string exePath = "";  if (m_Makefile->GetDefinition("EXECUTABLE_OUTPUT_PATH"))    {    exePath = m_Makefile->GetDefinition("EXECUTABLE_OUTPUT_PATH");    }  if(libPath.size())    {    // make sure there is a trailing slash    if(libPath[libPath.size()-1] != '/')      {      libPath += "/";      }    std::string lpath =       cmSystemTools::ConvertToOutputPath(libPath.c_str());    std::string lpathIntDir = libPath + "$(INTDIR)";    lpathIntDir =  cmSystemTools::ConvertToOutputPath(lpathIntDir.c_str());    if(pathEmitted.insert(lpath).second)      {      libOptions += " /LIBPATH:";      libOptions += lpathIntDir;      libOptions += " ";      libOptions += " /LIBPATH:";      libOptions += lpath;      libOptions += " ";      libMultiLineOptions += "# ADD LINK32 /LIBPATH:";      libMultiLineOptions += lpathIntDir;      libMultiLineOptions += " ";      libMultiLineOptions += " /LIBPATH:";      libMultiLineOptions += lpath;      libMultiLineOptions += " \n";      }    }  if(exePath.size())    {    // make sure there is a trailing slash    if(exePath[exePath.size()-1] != '/')      {      exePath += "/";      }    std::string lpath =       cmSystemTools::ConvertToOutputPath(exePath.c_str());    std::string lpathIntDir = exePath + "$(INTDIR)";    lpathIntDir =  cmSystemTools::ConvertToOutputPath(lpathIntDir.c_str());        if(pathEmitted.insert(lpath).second)      {      libOptions += " /LIBPATH:";      libOptions += lpathIntDir;      libOptions += " ";      libOptions += " /LIBPATH:";      libOptions += lpath;      libOptions += " ";      libMultiLineOptions += "# ADD LINK32 /LIBPATH:";      libMultiLineOptions += lpathIntDir;      libMultiLineOptions += " ";      libMultiLineOptions += " /LIBPATH:";      libMultiLineOptions += lpath;      libMultiLineOptions += " \n";      }    }  std::vector<std::string>::const_iterator i;  const std::vector<std::string>& libdirs = target.GetLinkDirectories();  for(i = libdirs.begin(); i != libdirs.end(); ++i)    {    std::string path = *i;    if(path[path.size()-1] != '/')      {      path += "/";      }    std::string lpath =       cmSystemTools::ConvertToOutputPath(path.c_str());    std::string lpathIntDir = path + "$(INTDIR)";    lpathIntDir =  cmSystemTools::ConvertToOutputPath(lpathIntDir.c_str());    if(pathEmitted.insert(lpath).second)      {      libOptions += " /LIBPATH:";      libOptions += lpathIntDir;      libOptions += " ";      libOptions += " /LIBPATH:";      libOptions += lpath;      libOptions += " ";            libMultiLineOptions += "# ADD LINK32 /LIBPATH:";      libMultiLineOptions += lpathIntDir;      libMultiLineOptions += " ";      libMultiLineOptions += " /LIBPATH:";      libMultiLineOptions += lpath;      libMultiLineOptions += " \n";      }    }    // find link libraries  const cmTarget::LinkLibraries& libs = target.GetLinkLibraries();  cmTarget::LinkLibraries::const_iterator j;  for(j = libs.begin(); j != libs.end(); ++j)    {    // add libraries to executables and dlls (but never include    // a library in a library, bad recursion)    if ((target.GetType() != cmTarget::SHARED_LIBRARY         && target.GetType() != cmTarget::STATIC_LIBRARY) ||         (target.GetType() == cmTarget::SHARED_LIBRARY && libName != j->first))      {      std::string lib = j->first;      if(j->first.find(".lib") == std::string::npos)        {        lib += ".lib";        }      lib = cmSystemTools::ConvertToOutputPath(lib.c_str());      if (j->second == cmTarget::GENERAL)        {        libOptions += " ";        libOptions += lib;                libMultiLineOptions += "# ADD LINK32 ";        libMultiLineOptions +=  lib;        libMultiLineOptions += "\n";        }      if (j->second == cmTarget::DEBUG)        {        libDebugOptions += " ";        libDebugOptions += lib;        libMultiLineDebugOptions += "# ADD LINK32 ";        libMultiLineDebugOptions += lib;        libMultiLineDebugOptions += "\n";        }      if (j->second == cmTarget::OPTIMIZED)        {        libOptimizedOptions += " ";        libOptimizedOptions += lib;        libMultiLineOptimizedOptions += "# ADD LINK32 ";        libMultiLineOptimizedOptions += lib;        libMultiLineOptimizedOptions += "\n";        }            }    }  std::string extraLinkOptions =     m_Makefile->GetDefinition("CMAKE_EXTRA_LINK_FLAGS");  if(extraLinkOptions.size())    {    libOptions += " ";    libOptions += extraLinkOptions;    libOptions += " ";    libMultiLineOptions += "# ADD LINK32 ";    libMultiLineOptions +=  extraLinkOptions;    libMultiLineOptions += " \n";    }    // are there any custom rules on the target itself  // only if the target is a lib or exe  std::string customRuleCode = this->CreateTargetRules(target, libName);  std::ifstream fin(m_DSPHeaderTemplate.c_str());  if(!fin)    {    cmSystemTools::Error("Error Reading ", m_DSPHeaderTemplate.c_str());    }  char buffer[2048];  while(fin)    {      fin.getline(buffer, 2048);      std::string line = buffer;      const char* mfcFlag = m_Makefile->GetDefinition("CMAKE_MFC_FLAG");      if(!mfcFlag)        {        mfcFlag = "0";        }      cmSystemTools::ReplaceString(line, "CMAKE_CUSTOM_RULE_CODE",                                   customRuleCode.c_str());      cmSystemTools::ReplaceString(line, "CMAKE_MFC_FLAG",                                   mfcFlag);      cmSystemTools::ReplaceString(line, "CM_LIBRARIES",                                   libOptions.c_str());      cmSystemTools::ReplaceString(line, "CM_DEBUG_LIBRARIES",                                   libDebugOptions.c_str());      cmSystemTools::ReplaceString(line, "CM_OPTIMIZED_LIBRARIES",                                   libOptimizedOptions.c_str());      cmSystemTools::ReplaceString(line, "CM_MULTILINE_LIBRARIES",                                   libMultiLineOptions.c_str());      cmSystemTools::ReplaceString(line, "CM_MULTILINE_DEBUG_LIBRARIES",                                   libMultiLineDebugOptions.c_str());      cmSystemTools::ReplaceString(line, "CM_MULTILINE_OPTIMIZED_LIBRARIES",                                   libMultiLineOptimizedOptions.c_str());      cmSystemTools::ReplaceString(line, "BUILD_INCLUDES",                                   m_IncludeOptions.c_str());      cmSystemTools::ReplaceString(line, "OUTPUT_LIBNAME",libName);      // because LIBRARY_OUTPUT_PATH and EXECUTABLE_OUTPUT_PATH       // are already quoted in the template file,      // we need to remove the quotes here, we still need      // to convert to output path for unix to win32 conversion      cmSystemTools::ReplaceString(line, "LIBRARY_OUTPUT_PATH",                                   removeQuotes(                                     cmSystemTools::ConvertToOutputPath(libPath.c_str())).c_str());      cmSystemTools::ReplaceString(line, "EXECUTABLE_OUTPUT_PATH",                                   removeQuotes(                                     cmSystemTools::ConvertToOutputPath(exePath.c_str())).c_str());      cmSystemTools::ReplaceString(line,                                    "EXTRA_DEFINES",                                    m_Makefile->GetDefineFlags());      std::string flags = m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_RELEASE");      flags += " -DCMAKE_INTDIR=\\\"Release\\\"";      cmSystemTools::ReplaceString(line, "CMAKE_CXX_FLAGS_RELEASE", flags.c_str());      flags = m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_MINSIZEREL");      flags += " -DCMAKE_INTDIR=\\\"MinSizeRel\\\"";      cmSystemTools::ReplaceString(line, "CMAKE_CXX_FLAGS_MINSIZEREL", flags.c_str());      flags = m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_DEBUG");      flags += " -DCMAKE_INTDIR=\\\"Debug\\\"";      cmSystemTools::ReplaceString(line, "CMAKE_CXX_FLAGS_DEBUG", flags.c_str());      flags = m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_RELWITHDEBINFO");      flags += " -DCMAKE_INTDIR=\\\"RelWithDebInfo\\\"";      cmSystemTools::ReplaceString(line,"CMAKE_CXX_FLAGS_RELWITHDEBINFO", flags.c_str());      cmSystemTools::ReplaceString(line, "CMAKE_CXX_FLAGS",                                   m_Makefile->                                   GetDefinition("CMAKE_CXX_FLAGS"));            fout << line.c_str() << std::endl;    }}void cmLocalVisualStudio6Generator::WriteDSPFooter(std::ostream& fout){    std::ifstream fin(m_DSPFooterTemplate.c_str());  if(!fin)    {    cmSystemTools::Error("Error Reading ",                         m_DSPFooterTemplate.c_str());    }  char buffer[2048];  while(fin)    {      fin.getline(buffer, 2048);      fout << buffer << std::endl;    }}
 |