| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 | /*=========================================================================  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 "cmSetSourceFilesPropertiesCommand.h"#include "cmSourceFile.h"// cmSetSourceFilesPropertiesCommandbool cmSetSourceFilesPropertiesCommand::InitialPass(  std::vector<std::string> const& args){  if(args.size() < 2 )    {    this->SetError("called with incorrect number of arguments");    return false;    }  // break the arguments into source file names and properties  int numFiles = 0;  std::vector<std::string>::const_iterator j;  j = args.begin();  // old style allows for specifier before PROPERTIES keyword  while (*j != "ABSTRACT" &&         *j != "WRAP_EXCLUDE" &&         *j != "GENERATED" &&         *j != "COMPILE_FLAGS" &&         *j != "OBJECT_DEPENDS" &&         *j != "PROPERTIES")    {    numFiles++;    ++j;    }  // now call the worker function   std::string errors;  bool ret =     cmSetSourceFilesPropertiesCommand    ::RunCommand(this->Makefile,                  args.begin(),                 args.begin() + numFiles,                 args.begin() + numFiles,                  args.end(), errors);  if (!ret)    {    this->SetError(errors.c_str());    }  return ret;}bool cmSetSourceFilesPropertiesCommand::RunCommand(cmMakefile *mf,             std::vector<std::string>::const_iterator filebeg,             std::vector<std::string>::const_iterator fileend,             std::vector<std::string>::const_iterator propbeg,             std::vector<std::string>::const_iterator propend,             std::string &errors){  std::vector<std::string> propertyPairs;  bool generated = false;  std::vector<std::string>::const_iterator j;  // build the property pairs  for(j= propbeg; j != propend;++j)    {    // old style allows for specifier before PROPERTIES keyword    if(*j == "ABSTRACT")      {      propertyPairs.push_back("ABSTRACT");      propertyPairs.push_back("1");      }    else if(*j == "WRAP_EXCLUDE")      {      propertyPairs.push_back("WRAP_EXCLUDE");      propertyPairs.push_back("1");      }    else if(*j == "GENERATED")      {      generated = true;      propertyPairs.push_back("GENERATED");      propertyPairs.push_back("1");      }    else if(*j == "COMPILE_FLAGS")      {      propertyPairs.push_back("COMPILE_FLAGS");      ++j;      if(j == propend)        {        errors = "called with incorrect number of arguments "          "COMPILE_FLAGS with no flags";        return false;        }      propertyPairs.push_back(*j);      }    else if(*j == "OBJECT_DEPENDS")      {      propertyPairs.push_back("OBJECT_DEPENDS");      ++j;      if(j == propend)        {        errors = "called with incorrect number of arguments "          "OBJECT_DEPENDS with no dependencies";        return false;        }      propertyPairs.push_back(*j);      }    else if(*j == "PROPERTIES")      {      // now loop through the rest of the arguments, new style      ++j;      bool dontPush = false;      while (j != propend)        {        propertyPairs.push_back(*j);        if(*j == "GENERATED")          {          ++j;          if(j != propend && cmSystemTools::IsOn(j->c_str()))            {            generated = true;            }          }        else if(*j == "MACOSX_PACKAGE_LOCATION")          {          ++j;          if(j == propend)            {            errors = "called with incorrect number of arguments "              "MACOSX_PACKAGE_LOCATION with no flags";            return false;            }          propertyPairs.push_back(*j);          propertyPairs.push_back("EXTRA_CONTENT");          propertyPairs.push_back("1");          propertyPairs.push_back("MACOSX_CONTENT");          propertyPairs.push_back("1");          propertyPairs.push_back("KEEP_EXTENSION");          propertyPairs.push_back("1");          propertyPairs.push_back("LANGUAGE");          propertyPairs.push_back("MacOSX_Content");          dontPush = true;          }        else          {          ++j;          }        if(j == propend)          {          errors = "called with incorrect number of arguments.";          return false;          }        if ( !dontPush )          {          propertyPairs.push_back(*j);          }        ++j;        dontPush = false;        }      // break out of the loop because j is already == end      break;      }    else      {      errors = "called with illegal arguments, maybe missing a "        "PROPERTIES specifier?";      return false;      }    }  // now loop over all the files  for(j= filebeg; j != fileend;++j)    {    // get the source file    cmSourceFile* sf =      mf->GetOrCreateSource(j->c_str(), generated);    if(sf)      {      // now loop through all the props and set them      unsigned int k;      for (k = 0; k < propertyPairs.size(); k = k + 2)        {        sf->SetProperty(propertyPairs[k].c_str(),propertyPairs[k+1].c_str());        }      }    }  return true;}
 |