瀏覽代碼

Centralize maintenance of usage requirement include directories

Maintain a target's internal list of usage requirement include
directories whenever the LINK_LIBRARIES property is set by either
target_link_libraries or set_property.
Stephen Kelly 12 年之前
父節點
當前提交
b8259c3d69
共有 3 個文件被更改,包括 17 次插入15 次删除
  1. 17 6
      Source/cmTarget.cxx
  2. 0 1
      Source/cmTarget.h
  3. 0 8
      Source/cmTargetLinkLibrariesCommand.cxx

+ 17 - 6
Source/cmTarget.cxx

@@ -2706,6 +2706,15 @@ void cmTarget::SetProperty(const char* prop, const char* value)
                           new cmTargetInternals::IncludeDirectoriesEntry(cge));
                           new cmTargetInternals::IncludeDirectoriesEntry(cge));
     return;
     return;
     }
     }
+  if (strcmp(prop, "LINK_LIBRARIES") == 0)
+    {
+    this->Internal->LinkInterfaceIncludeDirectoriesEntries.clear();
+    cmListFileBacktrace lfbt;
+    this->Makefile->GetBacktrace(lfbt);
+    cmValueWithOrigin entry(value, lfbt);
+    this->Internal->LinkInterfaceIncludeDirectoriesEntries.push_back(entry);
+    // Fall through
+    }
   this->Properties.SetProperty(prop, value, cmProperty::TARGET);
   this->Properties.SetProperty(prop, value, cmProperty::TARGET);
   this->MaybeInvalidatePropertyCache(prop);
   this->MaybeInvalidatePropertyCache(prop);
 }
 }
@@ -2727,6 +2736,14 @@ void cmTarget::AppendProperty(const char* prop, const char* value,
               new cmTargetInternals::IncludeDirectoriesEntry(ge.Parse(value)));
               new cmTargetInternals::IncludeDirectoriesEntry(ge.Parse(value)));
     return;
     return;
     }
     }
+  if (strcmp(prop, "LINK_LIBRARIES") == 0)
+    {
+    cmListFileBacktrace lfbt;
+    this->Makefile->GetBacktrace(lfbt);
+    cmValueWithOrigin entry(value, lfbt);
+    this->Internal->LinkInterfaceIncludeDirectoriesEntries.push_back(entry);
+    // Fall through
+    }
   this->Properties.AppendProperty(prop, value, cmProperty::TARGET, asString);
   this->Properties.AppendProperty(prop, value, cmProperty::TARGET, asString);
   this->MaybeInvalidatePropertyCache(prop);
   this->MaybeInvalidatePropertyCache(prop);
 }
 }
@@ -2762,12 +2779,6 @@ void cmTarget::AppendBuildInterfaceIncludes()
     }
     }
 }
 }
 
 
-//----------------------------------------------------------------------------
-void cmTarget::AppendTllInclude(const cmValueWithOrigin &entry)
-{
-  this->Internal->LinkInterfaceIncludeDirectoriesEntries.push_back(entry);
-}
-
 //----------------------------------------------------------------------------
 //----------------------------------------------------------------------------
 void cmTarget::InsertInclude(const cmValueWithOrigin &entry,
 void cmTarget::InsertInclude(const cmValueWithOrigin &entry,
                      bool before)
                      bool before)

+ 0 - 1
Source/cmTarget.h

@@ -495,7 +495,6 @@ public:
   std::vector<std::string> GetIncludeDirectories(const char *config);
   std::vector<std::string> GetIncludeDirectories(const char *config);
   void InsertInclude(const cmValueWithOrigin &entry,
   void InsertInclude(const cmValueWithOrigin &entry,
                      bool before = false);
                      bool before = false);
-  void AppendTllInclude(const cmValueWithOrigin &entry);
 
 
   void AppendBuildInterfaceIncludes();
   void AppendBuildInterfaceIncludes();
 
 

+ 0 - 8
Source/cmTargetLinkLibrariesCommand.cxx

@@ -259,14 +259,6 @@ cmTargetLinkLibrariesCommand::HandleLibrary(const char* lib,
   // Handle normal case first.
   // Handle normal case first.
   if(this->CurrentProcessingState != ProcessingLinkInterface)
   if(this->CurrentProcessingState != ProcessingLinkInterface)
     {
     {
-    {
-    cmListFileBacktrace lfbt;
-    this->Makefile->GetBacktrace(lfbt);
-    cmValueWithOrigin entry(this->Target->GetDebugGeneratorExpressions(lib,
-                                                                       llt),
-                            lfbt);
-    this->Target->AppendTllInclude(entry);
-    }
     this->Makefile
     this->Makefile
       ->AddLinkLibraryForTarget(this->Target->GetName(), lib, llt);
       ->AddLinkLibraryForTarget(this->Target->GetName(), lib, llt);
     if (this->CurrentProcessingState != ProcessingPublicInterface)
     if (this->CurrentProcessingState != ProcessingPublicInterface)