cmTarget: Refactor internal LinkInterface map

Create the map entry up front and store in it boolean values indicating
which pieces of the LinkInterface structure have been populated.
This approach leads to shorter code that is easier to follow too.
This commit is contained in:
Brad King 2014-07-10 16:59:16 -04:00
parent 4db3990e9f
commit c69e8a5580
1 changed files with 18 additions and 28 deletions

View File

@ -112,9 +112,11 @@ public:
struct OptionalLinkInterface: public cmTarget::LinkInterface struct OptionalLinkInterface: public cmTarget::LinkInterface
{ {
OptionalLinkInterface(): OptionalLinkInterface():
Exists(false), Complete(false), ExplicitLibraries(0) {} LibrariesDone(false), AllDone(false),
Exists(false), ExplicitLibraries(0) {}
bool LibrariesDone;
bool AllDone;
bool Exists; bool Exists;
bool Complete;
const char* ExplicitLibraries; const char* ExplicitLibraries;
}; };
void ComputeLinkInterface(cmTarget const* thisTarget, void ComputeLinkInterface(cmTarget const* thisTarget,
@ -5895,32 +5897,26 @@ cmTarget::LinkInterface const* cmTarget::GetLinkInterface(
// Lookup any existing link interface for this configuration. // Lookup any existing link interface for this configuration.
TargetConfigPair key(head, cmSystemTools::UpperCase(config)); TargetConfigPair key(head, cmSystemTools::UpperCase(config));
cmTargetInternals::LinkInterfaceMapType::iterator cmTargetInternals::OptionalLinkInterface&
i = this->Internal->LinkInterfaceMap.find(key); iface = this->Internal->LinkInterfaceMap[key];
if(i == this->Internal->LinkInterfaceMap.end()) if(!iface.LibrariesDone)
{ {
// Compute the link interface for this configuration. iface.LibrariesDone = true;
cmTargetInternals::OptionalLinkInterface iface;
iface.ExplicitLibraries = iface.ExplicitLibraries =
this->ComputeLinkInterfaceLibraries(config, iface, head, false, this->ComputeLinkInterfaceLibraries(config, iface, head, false,
iface.Exists); iface.Exists);
if (iface.Exists) }
if(!iface.AllDone)
{
iface.AllDone = true;
if(iface.Exists)
{ {
this->Internal->ComputeLinkInterface(this, config, iface, this->Internal->ComputeLinkInterface(this, config, iface,
head, iface.ExplicitLibraries); head, iface.ExplicitLibraries);
} }
// Store the information for this configuration.
cmTargetInternals::LinkInterfaceMapType::value_type entry(key, iface);
i = this->Internal->LinkInterfaceMap.insert(entry).first;
}
else if(!i->second.Complete && i->second.Exists)
{
this->Internal->ComputeLinkInterface(this, config, i->second, head,
i->second.ExplicitLibraries);
} }
return i->second.Exists ? &i->second : 0; return iface.Exists? &iface : 0;
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@ -5950,22 +5946,17 @@ cmTarget::GetLinkInterfaceLibraries(const std::string& config,
this->Internal->LinkInterfaceUsageRequirementsOnlyMap : this->Internal->LinkInterfaceUsageRequirementsOnlyMap :
this->Internal->LinkInterfaceMap); this->Internal->LinkInterfaceMap);
cmTargetInternals::LinkInterfaceMapType::iterator i = lim.find(key); cmTargetInternals::OptionalLinkInterface& iface = lim[key];
if(i == lim.end()) if(!iface.LibrariesDone)
{ {
// Compute the link interface for this configuration. iface.LibrariesDone = true;
cmTargetInternals::OptionalLinkInterface iface;
iface.ExplicitLibraries = iface.ExplicitLibraries =
this->ComputeLinkInterfaceLibraries(config, iface, head, this->ComputeLinkInterfaceLibraries(config, iface, head,
usage_requirements_only, usage_requirements_only,
iface.Exists); iface.Exists);
// Store the information for this configuration.
cmTargetInternals::LinkInterfaceMapType::value_type entry(key, iface);
i = lim.insert(entry).first;
} }
return i->second.Exists ? &i->second : 0; return iface.Exists? &iface : 0;
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@ -6348,7 +6339,6 @@ void cmTargetInternals::ComputeLinkInterface(cmTarget const* thisTarget,
sscanf(reps, "%u", &iface.Multiplicity); sscanf(reps, "%u", &iface.Multiplicity);
} }
} }
iface.Complete = true;
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------