Sfoglia il codice sorgente

BUG: fix issue with CMAKE_CURENT_LIST_FILE reporting in funcitons

Ken Martin 18 anni fa
parent
commit
f69a6a7c8c
1 ha cambiato i file con 12 aggiunte e 2 eliminazioni
  1. 12 2
      Source/cmFunctionCommand.cxx

+ 12 - 2
Source/cmFunctionCommand.cxx

@@ -150,8 +150,6 @@ bool cmFunctionHelperCommand::InvokeInitialPass
   this->Makefile->AddDefinition("ARGN", argnDef.c_str());
 
   // Invoke all the functions that were collected in the block.
-  cmListFileFunction newLFF;
-
   // for each function
   for(unsigned int c = 0; c < this->Functions.size(); ++c)
     {
@@ -203,6 +201,18 @@ IsFunctionBlocked(const cmListFileFunction& lff, cmMakefile &mf)
       cmFunctionHelperCommand *f = new cmFunctionHelperCommand();
       f->Args = this->Args;
       f->Functions = this->Functions;
+      
+      // Set the FilePath on the arguments to match the function since it is
+      // not stored and the original values may be freed
+      for (unsigned int i = 0; i < f->Functions.size(); ++i)
+        {
+        for (unsigned int j = 0; j < f->Functions[i].Arguments.size(); ++j)
+          {
+          f->Functions[i].Arguments[j].FilePath = 
+            f->Functions[i].FilePath.c_str();
+          }
+        }
+
       std::string newName = "_" + this->Args[0];
       mf.GetCMakeInstance()->RenameCommand(this->Args[0].c_str(), 
                                            newName.c_str());