summaryrefslogtreecommitdiffstats
path: root/Source/cmCacheManager.cxx
diff options
context:
space:
mode:
authorAndy Cedilnik <andy.cedilnik@kitware.com>2003-08-02 13:33:23 (GMT)
committerAndy Cedilnik <andy.cedilnik@kitware.com>2003-08-02 13:33:23 (GMT)
commit32bfe66b5d261bfc6c9f43f045f56651b8f012ea (patch)
treeeb909fc898dac331525878465ae201305c177686 /Source/cmCacheManager.cxx
parent8a0e3c103b67914c95536e82f1cb71c34c11b1ef (diff)
downloadCMake-32bfe66b5d261bfc6c9f43f045f56651b8f012ea.zip
CMake-32bfe66b5d261bfc6c9f43f045f56651b8f012ea.tar.gz
CMake-32bfe66b5d261bfc6c9f43f045f56651b8f012ea.tar.bz2
BUG: Fix problem with uninitialized variables
Diffstat (limited to 'Source/cmCacheManager.cxx')
-rw-r--r--Source/cmCacheManager.cxx24
1 files changed, 20 insertions, 4 deletions
diff --git a/Source/cmCacheManager.cxx b/Source/cmCacheManager.cxx
index 4f272c9..a47bb22 100644
--- a/Source/cmCacheManager.cxx
+++ b/Source/cmCacheManager.cxx
@@ -247,6 +247,7 @@ bool cmCacheManager::LoadCache(const char* path,
}
else
{
+ e.m_Initialized = true;
m_Cache[entryKey] = e;
}
}
@@ -363,7 +364,7 @@ bool cmCacheManager::SaveCache(const char* path)
{
const CacheEntry& ce = (*i).second;
CacheEntryType t = ce.m_Type;
- if(t == cmCacheManager::UNINITIALIZED)
+ if(t == cmCacheManager::UNINITIALIZED || !ce.m_Initialized)
{
/*
// This should be added in, but is not for now.
@@ -423,6 +424,11 @@ bool cmCacheManager::SaveCache(const char* path)
for( cmCacheManager::CacheIterator i = this->NewIterator();
!i.IsAtEnd(); i.Next())
{
+ if ( !i.Initialized() )
+ {
+ continue;
+ }
+
CacheEntryType t = i.GetType();
bool advanced = i.PropertyExists("ADVANCED");
if ( advanced )
@@ -581,7 +587,8 @@ cmCacheManager::CacheIterator cmCacheManager::GetCacheIterator(const char *key)
const char* cmCacheManager::GetCacheValue(const char* key) const
{
CacheEntryMap::const_iterator i = m_Cache.find(key);
- if(i != m_Cache.end() && i->second.m_Type != cmCacheManager::UNINITIALIZED)
+ if(i != m_Cache.end() && i->second.m_Type != cmCacheManager::UNINITIALIZED &&
+ i->second.m_Initialized)
{
return i->second.m_Value.c_str();
}
@@ -616,10 +623,11 @@ void cmCacheManager::AddCacheEntry(const char* key,
if ( value )
{
e.m_Value = value;
+ e.m_Initialized = true;
}
else
{
- e.m_Value = "(none)";
+ e.m_Value = "";
}
e.m_Type = type;
// make sure we only use unix style paths
@@ -682,7 +690,15 @@ void cmCacheManager::CacheIterator::SetValue(const char* value)
return;
}
CacheEntry* entry = &this->GetEntry();
- entry->m_Value = value;
+ if ( value )
+ {
+ entry->m_Value = value;
+ entry->m_Initialized = true;
+ }
+ else
+ {
+ entry->m_Value = "";
+ }
}
const char* cmCacheManager::CacheIterator::GetProperty(const char* property) const