| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 | /*=========================================================================  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 "cmLocalVisualStudioGenerator.h"#include "cmMakefile.h"#include "cmSourceFile.h"#include "cmSystemTools.h"//----------------------------------------------------------------------------cmLocalVisualStudioGenerator::cmLocalVisualStudioGenerator(){  this->WindowsShell = true;}//----------------------------------------------------------------------------cmLocalVisualStudioGenerator::~cmLocalVisualStudioGenerator(){}//----------------------------------------------------------------------------bool cmLocalVisualStudioGenerator::SourceFileCompiles(const cmSourceFile* sf){  // Identify the language of the source file.  if(const char* lang = this->GetSourceFileLanguage(*sf))    {    // Check whether this source will actually be compiled.    return (!sf->GetCustomCommand() &&            !sf->GetPropertyAsBool("HEADER_FILE_ONLY") &&            !sf->GetPropertyAsBool("EXTERNAL_OBJECT"));    }  else    {    // Unknown source file language.  Assume it will not be compiled.    return false;    }}//----------------------------------------------------------------------------void cmLocalVisualStudioGenerator::ComputeObjectNameRequirements(std::vector<cmSourceGroup> const& sourceGroups){  // Clear the current set of requirements.  this->NeedObjectName.clear();  // Count the number of object files with each name.  Note that  // windows file names are not case sensitive.  std::map<cmStdString, int> objectNameCounts;  for(unsigned int i = 0; i < sourceGroups.size(); ++i)    {    cmSourceGroup sg = sourceGroups[i];    std::vector<const cmSourceFile*> const& srcs = sg.GetSourceFiles();    for(std::vector<const cmSourceFile*>::const_iterator s = srcs.begin();        s != srcs.end(); ++s)      {      const cmSourceFile* sf = *s;      if(this->SourceFileCompiles(sf))        {        std::string objectName =          cmSystemTools::LowerCase(            cmSystemTools::GetFilenameWithoutLastExtension(              sf->GetFullPath().c_str()));        objectName += ".obj";        objectNameCounts[objectName] += 1;        }      }    }  // For all source files producing duplicate names we need unique  // object name computation.  for(unsigned int i = 0; i < sourceGroups.size(); ++i)    {    cmSourceGroup sg = sourceGroups[i];    std::vector<const cmSourceFile*> const& srcs = sg.GetSourceFiles();    for(std::vector<const cmSourceFile*>::const_iterator s = srcs.begin();        s != srcs.end(); ++s)      {      const cmSourceFile* sf = *s;      if(this->SourceFileCompiles(sf))        {        std::string objectName =          cmSystemTools::LowerCase(            cmSystemTools::GetFilenameWithoutLastExtension(              sf->GetFullPath().c_str()));        objectName += ".obj";        if(objectNameCounts[objectName] > 1)          {          this->NeedObjectName.insert(sf);          }        }      }    }}//----------------------------------------------------------------------------std::stringcmLocalVisualStudioGenerator::ConstructScript(const cmCustomCommandLines& commandLines,                  const char* workingDirectory,                  const char* newline){  // Store the script in a string.  std::string script;  if(workingDirectory)    {    script += "cd ";    script += this->Convert(workingDirectory, START_OUTPUT, SHELL);    script += newline;    }  // for visual studio IDE add extra stuff to the PATH  // if CMAKE_MSVCIDE_RUN_PATH is set.  if(this->Makefile->GetDefinition("MSVC_IDE"))    {    const char* extraPath =      this->Makefile->GetDefinition("CMAKE_MSVCIDE_RUN_PATH");    if(extraPath)      {      script += "set PATH=";      script += extraPath;      script += ";%PATH%";      script += newline;      }    }  // Write each command on a single line.  for(cmCustomCommandLines::const_iterator cl = commandLines.begin();      cl != commandLines.end(); ++cl)    {    // Start with the command name.    const cmCustomCommandLine& commandLine = *cl;    script += this->Convert(commandLine[0].c_str(),START_OUTPUT,SHELL);    // Add the arguments.    for(unsigned int j=1;j < commandLine.size(); ++j)      {      script += " ";      script += this->EscapeForShell(commandLine[j].c_str());      }    // End the line.    script += newline;    }  return script;}
 |