summaryrefslogtreecommitdiffstats
path: root/Source/cmCacheManager.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmCacheManager.cxx')
-rw-r--r--Source/cmCacheManager.cxx50
1 files changed, 42 insertions, 8 deletions
diff --git a/Source/cmCacheManager.cxx b/Source/cmCacheManager.cxx
index 3715f09..7c01fe2 100644
--- a/Source/cmCacheManager.cxx
+++ b/Source/cmCacheManager.cxx
@@ -106,9 +106,18 @@ bool cmCacheManager::LoadCache(const char* path)
{
return this->LoadCache(path,true);
}
+
bool cmCacheManager::LoadCache(const char* path,
bool internal)
{
+ std::set<std::string> emptySet;
+ return this->LoadCache(path, internal, emptySet);
+}
+
+bool cmCacheManager::LoadCache(const char* path,
+ bool internal,
+ std::set<std::string>& excludes)
+{
std::string cacheFile = path;
cacheFile += "/CMakeCache.txt";
// clear the old cache, if we are reading in internal values
@@ -127,6 +136,9 @@ bool cmCacheManager::LoadCache(const char* path,
cmRegularExpression reg("^([^:]*):([^=]*)=(.*[^\t ]|[\t ]*)[\t ]*$");
// input line is: "key":type=value
cmRegularExpression regQuoted("^\"([^\"]*)\":([^=]*)=(.*[^\t ]|[\t ]*)[\t ]*$");
+
+ std::set<std::string>::const_iterator iter;
+ std::string entryKey;
while(fin)
{
// Format is key:type=value
@@ -148,22 +160,44 @@ bool cmCacheManager::LoadCache(const char* path,
}
if(regQuoted.find(buffer))
{
- e.m_Type = cmCacheManager::StringToType(regQuoted.match(2).c_str());
- // only load internal values if internal is set
- if (internal || e.m_Type != INTERNAL)
+ entryKey = regQuoted.match(1);
+ if ( excludes.find(entryKey) == excludes.end() )
{
+ e.m_Type = cmCacheManager::StringToType(regQuoted.match(2).c_str());
+ // only load internal values if internal is set
+ if (internal || e.m_Type != INTERNAL)
+ {
+ // If we are loading the cache from another project,
+ // make all loaded entries internal so that it is
+ // not visible in the gui
+ if (!internal)
+ {
+ e.m_Type = INTERNAL;
+ }
e.m_Value = regQuoted.match(3);
- m_Cache[regQuoted.match(1)] = e;
+ m_Cache[entryKey] = e;
+ }
}
}
else if (reg.find(buffer))
{
- e.m_Type = cmCacheManager::StringToType(reg.match(2).c_str());
- // only load internal values if internal is set
- if (internal || e.m_Type != INTERNAL)
+ entryKey = reg.match(1);
+ if ( excludes.find(entryKey) == excludes.end() )
{
+ e.m_Type = cmCacheManager::StringToType(reg.match(2).c_str());
+ // only load internal values if internal is set
+ if (internal || e.m_Type != INTERNAL)
+ {
+ // If we are loading the cache from another project,
+ // make all loaded entries internal so that it is
+ // not visible in the gui
+ if (!internal)
+ {
+ e.m_Type = INTERNAL;
+ }
e.m_Value = reg.match(3);
- m_Cache[reg.match(1)] = e;
+ m_Cache[entryKey] = e;
+ }
}
}
else