[cmake-commits] martink committed cmSetPropertiesCommand.cxx 1.5 1.6
	cmSetPropertiesCommand.h 1.2 1.3
	cmSetSourceFilesPropertiesCommand.cxx 1.16 1.17
	cmSetSourceFilesPropertiesCommand.h 1.11 1.12 cmake.cxx 1.277 1.278
    cmake-commits at cmake.org 
    cmake-commits at cmake.org
       
    Mon Dec 11 10:26:13 EST 2006
    
    
  
Update of /cvsroot/CMake/CMake/Source
In directory public:/mounts/ram/cvs-serv7424/Source
Modified Files:
	cmSetPropertiesCommand.cxx cmSetPropertiesCommand.h 
	cmSetSourceFilesPropertiesCommand.cxx 
	cmSetSourceFilesPropertiesCommand.h cmake.cxx 
Log Message:
ENH: improve SetProperties and fix a couple warnings
Index: cmSetPropertiesCommand.h
===================================================================
RCS file: /cvsroot/CMake/CMake/Source/cmSetPropertiesCommand.h,v
retrieving revision 1.2
retrieving revision 1.3
diff -u -d -r1.2 -r1.3
--- cmSetPropertiesCommand.h	7 Dec 2006 19:54:15 -0000	1.2
+++ cmSetPropertiesCommand.h	11 Dec 2006 15:26:10 -0000	1.3
@@ -56,7 +56,8 @@
         "                 PROPERTIES prop1 value1\n"
         "                 prop2 value2 ...)\n"
         "Set properties on something. The scope_value is either GLOBAL "
-        "DIRECTORY dir_name, TARGET tgt_name, or TEST test_name."
+        "DIRECTORY dir_name, TARGET tgt_name, SOURCE_FILE src_name, "
+        "or TEST test_name."
         ;
     }
   
Index: cmSetPropertiesCommand.cxx
===================================================================
RCS file: /cvsroot/CMake/CMake/Source/cmSetPropertiesCommand.cxx,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -d -r1.5 -r1.6
--- cmSetPropertiesCommand.cxx	8 Dec 2006 14:27:52 -0000	1.5
+++ cmSetPropertiesCommand.cxx	11 Dec 2006 15:26:10 -0000	1.6
@@ -17,6 +17,7 @@
 #include "cmSetPropertiesCommand.h"
 #include "cmSetTargetPropertiesCommand.h"
 #include "cmSetTestsPropertiesCommand.h"
+#include "cmSetSourceFilesPropertiesCommand.h"
 
 // cmSetPropertiesCommand
 bool cmSetPropertiesCommand::InitialPass(
@@ -93,6 +94,11 @@
     scope = cmProperty::TEST;
     scopeName = args[1].c_str();
     }
+  else if (args[0] == "SOURCE_FILE" && numFiles == 2)
+    {
+    scope = cmProperty::SOURCE_FILE;
+    scopeName = args[1].c_str();
+    }
   else
     {
     this->SetError("called with illegal arguments.");
@@ -151,7 +157,19 @@
       }
       break;
     case cmProperty::SOURCE_FILE:
-      // not implemented yet
+      {
+      std::string errors;
+      bool ret = cmSetSourceFilesPropertiesCommand::
+        RunCommand(this->Makefile,
+                   args.begin()+1, args.begin()+2,
+                   args.begin() + 2, args.end(),
+                   errors);
+      if (!ret)
+        {
+        this->SetError(errors.c_str());
+        }
+      return ret;
+      }
       break;
     }
 
Index: cmSetSourceFilesPropertiesCommand.h
===================================================================
RCS file: /cvsroot/CMake/CMake/Source/cmSetSourceFilesPropertiesCommand.h,v
retrieving revision 1.11
retrieving revision 1.12
diff -u -d -r1.11 -r1.12
--- cmSetSourceFilesPropertiesCommand.h	2 Oct 2006 14:20:53 -0000	1.11
+++ cmSetSourceFilesPropertiesCommand.h	11 Dec 2006 15:26:10 -0000	1.12
@@ -82,6 +82,13 @@
     }
   
   cmTypeMacro(cmSetSourceFilesPropertiesCommand, cmCommand);
+
+  static bool 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);
 };
 
 
Index: cmake.cxx
===================================================================
RCS file: /cvsroot/CMake/CMake/Source/cmake.cxx,v
retrieving revision 1.277
retrieving revision 1.278
diff -u -d -r1.277 -r1.278
--- cmake.cxx	8 Dec 2006 14:27:52 -0000	1.277
+++ cmake.cxx	11 Dec 2006 15:26:10 -0000	1.278
@@ -2854,19 +2854,14 @@
     {
     case cmProperty::GLOBAL:
       return this->GlobalProperties.IsPropertyChained(name);
-      break;
     case cmProperty::TARGET:
       return this->TargetProperties.IsPropertyChained(name);
-      break;
     case cmProperty::SOURCE_FILE:
       return this->SourceFileProperties.IsPropertyChained(name);
-      break;
     case cmProperty::DIRECTORY:
       return this->DirectoryProperties.IsPropertyChained(name);
-      break;  
     case cmProperty::TEST:
       return this->DirectoryProperties.IsPropertyChained(name);
-      break;
   }
 
   return false;
Index: cmSetSourceFilesPropertiesCommand.cxx
===================================================================
RCS file: /cvsroot/CMake/CMake/Source/cmSetSourceFilesPropertiesCommand.cxx,v
retrieving revision 1.16
retrieving revision 1.17
diff -u -d -r1.16 -r1.17
--- cmSetSourceFilesPropertiesCommand.cxx	6 Jul 2006 20:04:49 -0000	1.16
+++ cmSetSourceFilesPropertiesCommand.cxx	11 Dec 2006 15:26:10 -0000	1.17
@@ -28,56 +28,89 @@
     return false;
     }
 
-  // first collect up the list of files
+  // 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 doingFiles = true;
   bool generated = false;
-  int numFiles = 0;
   std::vector<std::string>::const_iterator j;
-  for(j= args.begin(); j != args.end();++j)
+  // build the property pairs
+  for(j= propbeg; j != propend;++j)
     {
     // old style allows for specifier before PROPERTIES keyword
     if(*j == "ABSTRACT")
       {
-      doingFiles = false;
       propertyPairs.push_back("ABSTRACT");
       propertyPairs.push_back("1");
       }
     else if(*j == "WRAP_EXCLUDE")
       {
-      doingFiles = false;
       propertyPairs.push_back("WRAP_EXCLUDE");
       propertyPairs.push_back("1");
       }
     else if(*j == "GENERATED")
       {
-      doingFiles = false;
       generated = true;
       propertyPairs.push_back("GENERATED");
       propertyPairs.push_back("1");
       }
     else if(*j == "COMPILE_FLAGS")
       {
-      doingFiles = false;
       propertyPairs.push_back("COMPILE_FLAGS");
       ++j;
-      if(j == args.end())
+      if(j == propend)
         {
-        this->SetError("called with incorrect number of arguments "
-          "COMPILE_FLAGS with no flags");
+        errors = "called with incorrect number of arguments "
+          "COMPILE_FLAGS with no flags";
         return false;
         }
       propertyPairs.push_back(*j);
       }
     else if(*j == "OBJECT_DEPENDS")
       {
-      doingFiles = false;
       propertyPairs.push_back("OBJECT_DEPENDS");
       ++j;
-      if(j == args.end())
+      if(j == propend)
         {
-        this->SetError("called with incorrect number of arguments "
-                       "OBJECT_DEPENDS with no dependencies");
+        errors = "called with incorrect number of arguments "
+          "OBJECT_DEPENDS with no dependencies";
         return false;
         }
       propertyPairs.push_back(*j);
@@ -87,13 +120,13 @@
       // now loop through the rest of the arguments, new style
       ++j;
       bool dontPush = false;
-      while (j != args.end())
+      while (j != propend)
         {
         propertyPairs.push_back(*j);
         if(*j == "GENERATED")
           {
           ++j;
-          if(j != args.end() && cmSystemTools::IsOn(j->c_str()))
+          if(j != propend && cmSystemTools::IsOn(j->c_str()))
             {
             generated = true;
             }
@@ -101,10 +134,10 @@
         else if(*j == "MACOSX_PACKAGE_LOCATION")
           {
           ++j;
-          if(j == args.end())
+          if(j == propend)
             {
-            this->SetError("called with incorrect number of arguments "
-              "MACOSX_PACKAGE_LOCATION with no flags");
+            errors = "called with incorrect number of arguments "
+              "MACOSX_PACKAGE_LOCATION with no flags";
             return false;
             }
           propertyPairs.push_back(*j);
@@ -122,9 +155,9 @@
           {
           ++j;
           }
-        if(j == args.end())
+        if(j == propend)
           {
-          this->SetError("called with incorrect number of arguments.");
+          errors = "called with incorrect number of arguments.";
           return false;
           }
         if ( !dontPush )
@@ -137,29 +170,24 @@
       // break out of the loop because j is already == end
       break;
       }
-    else if (doingFiles)
-      {
-      numFiles++;
-      }
     else
       {
-      this->SetError("called with illegal arguments, maybe missing a "
-        "PROPERTIES specifier?");
+      errors = "called with illegal arguments, maybe missing a "
+        "PROPERTIES specifier?";
       return false;
       }
     }
 
   // now loop over all the files
-  int i;
-  unsigned int k;
-  for(i = 0; i < numFiles; ++i)
+  for(j= filebeg; j != fileend;++j)
     {
     // get the source file
     cmSourceFile* sf =
-      this->Makefile->GetOrCreateSource(args[i].c_str(), generated);
+      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());
    
    
More information about the Cmake-commits
mailing list