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.
This commit is contained in:
parent
78185f598c
commit
b8259c3d69
|
@ -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)
|
||||||
|
|
|
@ -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();
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue