summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-07-07 15:30:36 (GMT)
committerBrad King <brad.king@kitware.com>2009-07-07 15:30:36 (GMT)
commit2247aca9cf6f9ade027be4b9558d1211647c6c3a (patch)
treed89f595c3395fa2252befb033a2af13ef5ceafa2
parentafbd595e859f1b7df946c77408adcef18c744ff5 (diff)
downloadCMake-2247aca9cf6f9ade027be4b9558d1211647c6c3a.zip
CMake-2247aca9cf6f9ade027be4b9558d1211647c6c3a.tar.gz
CMake-2247aca9cf6f9ade027be4b9558d1211647c6c3a.tar.bz2
BUG: Do not recompute link interfaces
The config-to-interface map in cmTarget should use case-insensitive configuration names. The change avoids repeating work if the given configuration has a different case than one already computed.
-rw-r--r--Source/cmTarget.cxx6
1 files changed, 3 insertions, 3 deletions
diff --git a/Source/cmTarget.cxx b/Source/cmTarget.cxx
index ae17b40..ae0fa87 100644
--- a/Source/cmTarget.cxx
+++ b/Source/cmTarget.cxx
@@ -3696,8 +3696,9 @@ cmTarget::LinkInterface const* cmTarget::GetLinkInterface(const char* config)
}
// Lookup any existing link interface for this configuration.
+ std::string key = cmSystemTools::UpperCase(config? config : "");
cmTargetInternals::LinkInterfaceMapType::iterator
- i = this->Internal->LinkInterfaceMap.find(config?config:"");
+ i = this->Internal->LinkInterfaceMap.find(key);
if(i == this->Internal->LinkInterfaceMap.end())
{
// Compute the link interface for this configuration.
@@ -3705,8 +3706,7 @@ cmTarget::LinkInterface const* cmTarget::GetLinkInterface(const char* config)
iface.Exists = this->ComputeLinkInterface(config, iface);
// Store the information for this configuration.
- cmTargetInternals::LinkInterfaceMapType::value_type
- entry(config?config:"", iface);
+ cmTargetInternals::LinkInterfaceMapType::value_type entry(key, iface);
i = this->Internal->LinkInterfaceMap.insert(entry).first;
}