cmTarget: Drop internal cache of build properties
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:
parent
a4d58722a4
commit
133cd996d1
|
@ -196,11 +196,9 @@ public:
|
||||||
public:
|
public:
|
||||||
TargetPropertyEntry(cmsys::auto_ptr<cmCompiledGeneratorExpression> cge,
|
TargetPropertyEntry(cmsys::auto_ptr<cmCompiledGeneratorExpression> cge,
|
||||||
cmLinkImplItem const& item = NoLinkImplItem)
|
cmLinkImplItem const& item = NoLinkImplItem)
|
||||||
: ge(cge), Cached(false), LinkImplItem(item)
|
: ge(cge), LinkImplItem(item)
|
||||||
{}
|
{}
|
||||||
const cmsys::auto_ptr<cmCompiledGeneratorExpression> ge;
|
const cmsys::auto_ptr<cmCompiledGeneratorExpression> ge;
|
||||||
std::vector<std::string> CachedEntries;
|
|
||||||
bool Cached;
|
|
||||||
cmLinkImplItem const& LinkImplItem;
|
cmLinkImplItem const& LinkImplItem;
|
||||||
};
|
};
|
||||||
std::vector<TargetPropertyEntry*> IncludeDirectoriesEntries;
|
std::vector<TargetPropertyEntry*> IncludeDirectoriesEntries;
|
||||||
|
@ -635,10 +633,7 @@ static bool processSources(cmTarget const* tgt,
|
||||||
for (std::vector<cmTargetInternals::TargetPropertyEntry*>::const_iterator
|
for (std::vector<cmTargetInternals::TargetPropertyEntry*>::const_iterator
|
||||||
it = entries.begin(), end = entries.end(); it != end; ++it)
|
it = entries.begin(), end = entries.end(); it != end; ++it)
|
||||||
{
|
{
|
||||||
bool cacheSources = false;
|
std::vector<std::string> entrySources;
|
||||||
std::vector<std::string> entrySources = (*it)->CachedEntries;
|
|
||||||
if(entrySources.empty())
|
|
||||||
{
|
|
||||||
cmSystemTools::ExpandListArgument((*it)->ge->Evaluate(mf,
|
cmSystemTools::ExpandListArgument((*it)->ge->Evaluate(mf,
|
||||||
config,
|
config,
|
||||||
false,
|
false,
|
||||||
|
@ -651,10 +646,6 @@ static bool processSources(cmTarget const* tgt,
|
||||||
{
|
{
|
||||||
contextDependent = true;
|
contextDependent = true;
|
||||||
}
|
}
|
||||||
else if (mf->IsGeneratingBuildSystem())
|
|
||||||
{
|
|
||||||
cacheSources = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(std::vector<std::string>::iterator i = entrySources.begin();
|
for(std::vector<std::string>::iterator i = entrySources.begin();
|
||||||
i != entrySources.end(); ++i)
|
i != entrySources.end(); ++i)
|
||||||
|
@ -675,11 +666,6 @@ static bool processSources(cmTarget const* tgt,
|
||||||
return contextDependent;
|
return contextDependent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (cacheSources)
|
|
||||||
{
|
|
||||||
(*it)->CachedEntries = entrySources;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
std::string usedSources;
|
std::string usedSources;
|
||||||
for(std::vector<std::string>::iterator
|
for(std::vector<std::string>::iterator
|
||||||
li = entrySources.begin(); li != entrySources.end(); ++li)
|
li = entrySources.begin(); li != entrySources.end(); ++li)
|
||||||
|
@ -2003,27 +1989,14 @@ static void processIncludeDirectories(cmTarget const* tgt,
|
||||||
std::string const& targetName = item;
|
std::string const& targetName = item;
|
||||||
bool const fromImported = item.Target && item.Target->IsImported();
|
bool const fromImported = item.Target && item.Target->IsImported();
|
||||||
bool const checkCMP0027 = item.FromGenex;
|
bool const checkCMP0027 = item.FromGenex;
|
||||||
bool testIsOff = true;
|
std::vector<std::string> entryIncludes;
|
||||||
bool cacheIncludes = false;
|
|
||||||
std::vector<std::string>& entryIncludes = (*it)->CachedEntries;
|
|
||||||
if(!entryIncludes.empty())
|
|
||||||
{
|
|
||||||
testIsOff = false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
cmSystemTools::ExpandListArgument((*it)->ge->Evaluate(mf,
|
cmSystemTools::ExpandListArgument((*it)->ge->Evaluate(mf,
|
||||||
config,
|
config,
|
||||||
false,
|
false,
|
||||||
tgt,
|
tgt,
|
||||||
dagChecker),
|
dagChecker),
|
||||||
entryIncludes);
|
entryIncludes);
|
||||||
if (mf->IsGeneratingBuildSystem()
|
|
||||||
&& !(*it)->ge->GetHadContextSensitiveCondition())
|
|
||||||
{
|
|
||||||
cacheIncludes = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
std::string usedIncludes;
|
std::string usedIncludes;
|
||||||
for(std::vector<std::string>::iterator
|
for(std::vector<std::string>::iterator
|
||||||
li = entryIncludes.begin(); li != entryIncludes.end(); ++li)
|
li = entryIncludes.begin(); li != entryIncludes.end(); ++li)
|
||||||
|
@ -2105,7 +2078,7 @@ static void processIncludeDirectories(cmTarget const* tgt,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (testIsOff && !cmSystemTools::IsOff(li->c_str()))
|
if (!cmSystemTools::IsOff(li->c_str()))
|
||||||
{
|
{
|
||||||
cmSystemTools::ConvertToUnixSlashes(*li);
|
cmSystemTools::ConvertToUnixSlashes(*li);
|
||||||
}
|
}
|
||||||
|
@ -2120,10 +2093,6 @@ static void processIncludeDirectories(cmTarget const* tgt,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (cacheIncludes)
|
|
||||||
{
|
|
||||||
(*it)->CachedEntries = entryIncludes;
|
|
||||||
}
|
|
||||||
if (!usedIncludes.empty())
|
if (!usedIncludes.empty())
|
||||||
{
|
{
|
||||||
mf->GetCMakeInstance()->IssueMessage(cmake::LOG,
|
mf->GetCMakeInstance()->IssueMessage(cmake::LOG,
|
||||||
|
@ -2229,33 +2198,16 @@ static void processCompileOptionsInternal(cmTarget const* tgt,
|
||||||
for (std::vector<cmTargetInternals::TargetPropertyEntry*>::const_iterator
|
for (std::vector<cmTargetInternals::TargetPropertyEntry*>::const_iterator
|
||||||
it = entries.begin(), end = entries.end(); it != end; ++it)
|
it = entries.begin(), end = entries.end(); it != end; ++it)
|
||||||
{
|
{
|
||||||
std::vector<std::string>& entriesRef = (*it)->CachedEntries;
|
std::vector<std::string> entryOptions;
|
||||||
std::vector<std::string> localEntries;
|
|
||||||
std::vector<std::string>* entryOptions = &entriesRef;
|
|
||||||
if(!(*it)->Cached)
|
|
||||||
{
|
|
||||||
cmSystemTools::ExpandListArgument((*it)->ge->Evaluate(mf,
|
cmSystemTools::ExpandListArgument((*it)->ge->Evaluate(mf,
|
||||||
config,
|
config,
|
||||||
false,
|
false,
|
||||||
tgt,
|
tgt,
|
||||||
dagChecker),
|
dagChecker),
|
||||||
localEntries);
|
entryOptions);
|
||||||
if (mf->IsGeneratingBuildSystem()
|
|
||||||
&& !(*it)->ge->GetHadContextSensitiveCondition())
|
|
||||||
{
|
|
||||||
// Cache the result.
|
|
||||||
*entryOptions = localEntries;
|
|
||||||
(*it)->Cached = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Use the context-sensitive results here.
|
|
||||||
entryOptions = &localEntries;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
std::string usedOptions;
|
std::string usedOptions;
|
||||||
for(std::vector<std::string>::iterator
|
for(std::vector<std::string>::iterator
|
||||||
li = entryOptions->begin(); li != entryOptions->end(); ++li)
|
li = entryOptions.begin(); li != entryOptions.end(); ++li)
|
||||||
{
|
{
|
||||||
std::string const& opt = *li;
|
std::string const& opt = *li;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue