cmTarget: Drop internal cache of link interface usage requirements

These use a huge amount of memory that accumulates as generation
proceeds.  On the Unix Makefiles generator, only GetIncludeDirectories
and GetCompileDefinitions are even called more than once per target
(once for build files, once for dependency scanning preprocessor info).
Another approach will be needed to avoid duplicate computation in the
cases where it does occur.
This commit is contained in:
Brad King 2014-07-18 13:57:57 -04:00
parent 23ec3738a0
commit a4d58722a4
1 changed files with 84 additions and 164 deletions

View File

@ -213,23 +213,6 @@ public:
void AddInterfaceEntries( void AddInterfaceEntries(
cmTarget const* thisTarget, std::string const& config, cmTarget const* thisTarget, std::string const& config,
std::string const& prop, std::vector<TargetPropertyEntry*>& entries); std::string const& prop, std::vector<TargetPropertyEntry*>& entries);
std::map<std::string, std::vector<TargetPropertyEntry*> >
CachedLinkInterfaceIncludeDirectoriesEntries;
std::map<std::string, std::vector<TargetPropertyEntry*> >
CachedLinkInterfaceCompileOptionsEntries;
std::map<std::string, std::vector<TargetPropertyEntry*> >
CachedLinkInterfaceCompileDefinitionsEntries;
std::map<std::string, std::vector<TargetPropertyEntry*> >
CachedLinkInterfaceSourcesEntries;
std::map<std::string, std::vector<TargetPropertyEntry*> >
CachedLinkInterfaceCompileFeaturesEntries;
std::map<std::string, bool> CacheLinkInterfaceIncludeDirectoriesDone;
std::map<std::string, bool> CacheLinkInterfaceCompileDefinitionsDone;
std::map<std::string, bool> CacheLinkInterfaceCompileOptionsDone;
std::map<std::string, bool> CacheLinkInterfaceSourcesDone;
std::map<std::string, bool> CacheLinkInterfaceCompileFeaturesDone;
}; };
cmLinkImplItem cmTargetInternals::TargetPropertyEntry::NoLinkImplItem; cmLinkImplItem cmTargetInternals::TargetPropertyEntry::NoLinkImplItem;
@ -248,27 +231,9 @@ static void deleteAndClear(
entries.clear(); entries.clear();
} }
//----------------------------------------------------------------------------
static void deleteAndClear(
std::map<std::string,
std::vector<cmTargetInternals::TargetPropertyEntry*> > &entries)
{
for (std::map<std::string,
std::vector<cmTargetInternals::TargetPropertyEntry*> >::iterator
it = entries.begin(), end = entries.end(); it != end; ++it)
{
deleteAndClear(it->second);
}
}
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
cmTargetInternals::~cmTargetInternals() cmTargetInternals::~cmTargetInternals()
{ {
deleteAndClear(this->CachedLinkInterfaceIncludeDirectoriesEntries);
deleteAndClear(this->CachedLinkInterfaceCompileOptionsEntries);
deleteAndClear(this->CachedLinkInterfaceCompileFeaturesEntries);
deleteAndClear(this->CachedLinkInterfaceCompileDefinitionsEntries);
deleteAndClear(this->CachedLinkInterfaceSourcesEntries);
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@ -810,16 +775,16 @@ void cmTarget::GetSourceFiles(std::vector<std::string> &files,
config, config,
debugSources); debugSources);
if (!this->Internal->CacheLinkInterfaceSourcesDone[config]) std::vector<cmTargetInternals::TargetPropertyEntry*>
{ linkInterfaceSourcesEntries;
this->Internal->AddInterfaceEntries(
this, config, "INTERFACE_SOURCES",
this->Internal->CachedLinkInterfaceSourcesEntries[config]);
}
std::vector<std::string>::size_type numFilesBefore = files.size(); this->Internal->AddInterfaceEntries(
bool contextDependentInterfaceSources = processSources(this, this, config, "INTERFACE_SOURCES",
this->Internal->CachedLinkInterfaceSourcesEntries[config], linkInterfaceSourcesEntries);
std::vector<std::string>::size_type numFilesBefore = files.size();
bool contextDependentInterfaceSources = processSources(this,
linkInterfaceSourcesEntries,
files, files,
uniqueSrcs, uniqueSrcs,
&dagChecker, &dagChecker,
@ -832,14 +797,7 @@ void cmTarget::GetSourceFiles(std::vector<std::string> &files,
this->LinkImplementationLanguageIsContextDependent = false; this->LinkImplementationLanguageIsContextDependent = false;
} }
if (!this->Makefile->IsGeneratingBuildSystem()) deleteAndClear(linkInterfaceSourcesEntries);
{
deleteAndClear(this->Internal->CachedLinkInterfaceSourcesEntries);
}
else
{
this->Internal->CacheLinkInterfaceSourcesDone[config] = true;
}
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@ -2213,58 +2171,47 @@ cmTarget::GetIncludeDirectories(const std::string& config) const
config, config,
debugIncludes); debugIncludes);
if (!this->Internal->CacheLinkInterfaceIncludeDirectoriesDone[config]) std::vector<cmTargetInternals::TargetPropertyEntry*>
linkInterfaceIncludeDirectoriesEntries;
this->Internal->AddInterfaceEntries(
this, config, "INTERFACE_INCLUDE_DIRECTORIES",
linkInterfaceIncludeDirectoriesEntries);
if(this->Makefile->IsOn("APPLE"))
{ {
this->Internal->AddInterfaceEntries( LinkImplementation const* impl = this->GetLinkImplementation(config);
this, config, "INTERFACE_INCLUDE_DIRECTORIES", for(std::vector<cmLinkImplItem>::const_iterator
this->Internal->CachedLinkInterfaceIncludeDirectoriesEntries[config]); it = impl->Libraries.begin();
it != impl->Libraries.end(); ++it)
if(this->Makefile->IsOn("APPLE"))
{ {
LinkImplementation const* impl = this->GetLinkImplementation(config); std::string libDir = cmSystemTools::CollapseFullPath(it->c_str());
for(std::vector<cmLinkImplItem>::const_iterator
it = impl->Libraries.begin(); static cmsys::RegularExpression
it != impl->Libraries.end(); ++it) frameworkCheck("(.*\\.framework)(/Versions/[^/]+)?/[^/]+$");
if(!frameworkCheck.find(libDir))
{ {
std::string libDir = cmSystemTools::CollapseFullPath(it->c_str()); continue;
static cmsys::RegularExpression
frameworkCheck("(.*\\.framework)(/Versions/[^/]+)?/[^/]+$");
if(!frameworkCheck.find(libDir))
{
continue;
}
libDir = frameworkCheck.match(1);
cmGeneratorExpression ge;
cmsys::auto_ptr<cmCompiledGeneratorExpression> cge =
ge.Parse(libDir.c_str());
this->Internal
->CachedLinkInterfaceIncludeDirectoriesEntries[config]
.push_back(new cmTargetInternals::TargetPropertyEntry(cge));
} }
libDir = frameworkCheck.match(1);
cmGeneratorExpression ge;
cmsys::auto_ptr<cmCompiledGeneratorExpression> cge =
ge.Parse(libDir.c_str());
linkInterfaceIncludeDirectoriesEntries
.push_back(new cmTargetInternals::TargetPropertyEntry(cge));
} }
} }
processIncludeDirectories(this, processIncludeDirectories(this,
this->Internal->CachedLinkInterfaceIncludeDirectoriesEntries[config], linkInterfaceIncludeDirectoriesEntries,
includes, includes,
uniqueIncludes, uniqueIncludes,
&dagChecker, &dagChecker,
config, config,
debugIncludes); debugIncludes);
if (!this->Makefile->IsGeneratingBuildSystem()) deleteAndClear(linkInterfaceIncludeDirectoriesEntries);
{
deleteAndClear(
this->Internal->CachedLinkInterfaceIncludeDirectoriesEntries);
}
else
{
this->Internal->CacheLinkInterfaceIncludeDirectoriesDone[config]
= true;
}
return includes; return includes;
} }
@ -2405,29 +2352,22 @@ void cmTarget::GetCompileOptions(std::vector<std::string> &result,
config, config,
debugOptions); debugOptions);
if (!this->Internal->CacheLinkInterfaceCompileOptionsDone[config]) std::vector<cmTargetInternals::TargetPropertyEntry*>
{ linkInterfaceCompileOptionsEntries;
this->Internal->AddInterfaceEntries(
this, config, "INTERFACE_COMPILE_OPTIONS", this->Internal->AddInterfaceEntries(
this->Internal->CachedLinkInterfaceCompileOptionsEntries[config]); this, config, "INTERFACE_COMPILE_OPTIONS",
} linkInterfaceCompileOptionsEntries);
processCompileOptions(this, processCompileOptions(this,
this->Internal->CachedLinkInterfaceCompileOptionsEntries[config], linkInterfaceCompileOptionsEntries,
result, result,
uniqueOptions, uniqueOptions,
&dagChecker, &dagChecker,
config, config,
debugOptions); debugOptions);
if (!this->Makefile->IsGeneratingBuildSystem()) deleteAndClear(linkInterfaceCompileOptionsEntries);
{
deleteAndClear(this->Internal->CachedLinkInterfaceCompileOptionsEntries);
}
else
{
this->Internal->CacheLinkInterfaceCompileOptionsDone[config] = true;
}
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@ -2479,66 +2419,54 @@ void cmTarget::GetCompileDefinitions(std::vector<std::string> &list,
config, config,
debugDefines); debugDefines);
if (!this->Internal->CacheLinkInterfaceCompileDefinitionsDone[config]) std::vector<cmTargetInternals::TargetPropertyEntry*>
linkInterfaceCompileDefinitionsEntries;
this->Internal->AddInterfaceEntries(
this, config, "INTERFACE_COMPILE_DEFINITIONS",
linkInterfaceCompileDefinitionsEntries);
if (!config.empty())
{ {
this->Internal->AddInterfaceEntries( std::string configPropName = "COMPILE_DEFINITIONS_"
this, config, "INTERFACE_COMPILE_DEFINITIONS", + cmSystemTools::UpperCase(config);
this->Internal->CachedLinkInterfaceCompileDefinitionsEntries[config]); const char *configProp = this->GetProperty(configPropName);
if (!config.empty()) if (configProp)
{ {
std::string configPropName = "COMPILE_DEFINITIONS_" switch(this->Makefile->GetPolicyStatus(cmPolicies::CMP0043))
+ cmSystemTools::UpperCase(config);
const char *configProp = this->GetProperty(configPropName);
if (configProp)
{ {
switch(this->Makefile->GetPolicyStatus(cmPolicies::CMP0043)) case cmPolicies::WARN:
{ {
case cmPolicies::WARN: cmOStringStream e;
{ e << this->Makefile->GetCMakeInstance()->GetPolicies()
cmOStringStream e; ->GetPolicyWarning(cmPolicies::CMP0043);
e << this->Makefile->GetCMakeInstance()->GetPolicies() this->Makefile->IssueMessage(cmake::AUTHOR_WARNING,
->GetPolicyWarning(cmPolicies::CMP0043); e.str());
this->Makefile->IssueMessage(cmake::AUTHOR_WARNING,
e.str());
}
case cmPolicies::OLD:
{
cmGeneratorExpression ge;
cmsys::auto_ptr<cmCompiledGeneratorExpression> cge =
ge.Parse(configProp);
this->Internal
->CachedLinkInterfaceCompileDefinitionsEntries[config]
.push_back(new cmTargetInternals::TargetPropertyEntry(cge));
}
break;
case cmPolicies::NEW:
case cmPolicies::REQUIRED_ALWAYS:
case cmPolicies::REQUIRED_IF_USED:
break;
} }
case cmPolicies::OLD:
{
cmGeneratorExpression ge;
cmsys::auto_ptr<cmCompiledGeneratorExpression> cge =
ge.Parse(configProp);
linkInterfaceCompileDefinitionsEntries
.push_back(new cmTargetInternals::TargetPropertyEntry(cge));
}
break;
case cmPolicies::NEW:
case cmPolicies::REQUIRED_ALWAYS:
case cmPolicies::REQUIRED_IF_USED:
break;
} }
} }
} }
processCompileDefinitions(this, processCompileDefinitions(this,
this->Internal->CachedLinkInterfaceCompileDefinitionsEntries[config], linkInterfaceCompileDefinitionsEntries,
list, list,
uniqueOptions, uniqueOptions,
&dagChecker, &dagChecker,
config, config,
debugDefines); debugDefines);
if (!this->Makefile->IsGeneratingBuildSystem()) deleteAndClear(linkInterfaceCompileDefinitionsEntries);
{
deleteAndClear(this->Internal
->CachedLinkInterfaceCompileDefinitionsEntries);
}
else
{
this->Internal->CacheLinkInterfaceCompileDefinitionsDone[config]
= true;
}
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@ -2590,29 +2518,21 @@ void cmTarget::GetCompileFeatures(std::vector<std::string> &result,
config, config,
debugFeatures); debugFeatures);
if (!this->Internal->CacheLinkInterfaceCompileFeaturesDone[config]) std::vector<cmTargetInternals::TargetPropertyEntry*>
{ linkInterfaceCompileFeaturesEntries;
this->Internal->AddInterfaceEntries( this->Internal->AddInterfaceEntries(
this, config, "INTERFACE_COMPILE_FEATURES", this, config, "INTERFACE_COMPILE_FEATURES",
this->Internal->CachedLinkInterfaceCompileFeaturesEntries[config]); linkInterfaceCompileFeaturesEntries);
}
processCompileFeatures(this, processCompileFeatures(this,
this->Internal->CachedLinkInterfaceCompileFeaturesEntries[config], linkInterfaceCompileFeaturesEntries,
result, result,
uniqueFeatures, uniqueFeatures,
&dagChecker, &dagChecker,
config, config,
debugFeatures); debugFeatures);
if (!this->Makefile->IsGeneratingBuildSystem()) deleteAndClear(linkInterfaceCompileFeaturesEntries);
{
deleteAndClear(this->Internal->CachedLinkInterfaceCompileFeaturesEntries);
}
else
{
this->Internal->CacheLinkInterfaceCompileFeaturesDone[config] = true;
}
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------