summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2003-02-05 19:55:46 (GMT)
committerBrad King <brad.king@kitware.com>2003-02-05 19:55:46 (GMT)
commit5bcd9203c338b5b9e0f3b12487a228a1d4dd504f (patch)
tree7f0b43c506063e84ae8e3386fd66395413a20241
parent4c22977685f2eae8ef57dfaeaf09280c78d6ebd4 (diff)
downloadCMake-5bcd9203c338b5b9e0f3b12487a228a1d4dd504f.zip
CMake-5bcd9203c338b5b9e0f3b12487a228a1d4dd504f.tar.gz
CMake-5bcd9203c338b5b9e0f3b12487a228a1d4dd504f.tar.bz2
ENH: Better error checking for cache iterator.
-rw-r--r--Source/cmCacheManager.cxx41
-rw-r--r--Source/cmCacheManager.h2
2 files changed, 40 insertions, 3 deletions
diff --git a/Source/cmCacheManager.cxx b/Source/cmCacheManager.cxx
index 8609db3..92a04cf 100644
--- a/Source/cmCacheManager.cxx
+++ b/Source/cmCacheManager.cxx
@@ -605,7 +605,7 @@ void cmCacheManager::AddCacheEntry(const char* key, bool v,
}
}
-bool cmCacheManager::CacheIterator::IsAtEnd()
+bool cmCacheManager::CacheIterator::IsAtEnd() const
{
return m_Position == m_Container.m_Cache.end();
}
@@ -623,17 +623,30 @@ bool cmCacheManager::CacheIterator::Find(const char* key)
void cmCacheManager::CacheIterator::Next()
{
- ++m_Position;
+ if (!this->IsAtEnd())
+ {
+ ++m_Position;
+ }
}
void cmCacheManager::CacheIterator::SetValue(const char* value)
{
+ if (this->IsAtEnd())
+ {
+ return;
+ }
CacheEntry* entry = &this->GetEntry();
entry->m_Value = value;
}
const char* cmCacheManager::CacheIterator::GetProperty(const char* property) const
{
+ // make sure it is not at the end
+ if (this->IsAtEnd())
+ {
+ return 0;
+ }
+
if ( !strcmp(property, "TYPE") || !strcmp(property, "VALUE") )
{
cmSystemTools::Error("Property \"", property,
@@ -652,6 +665,12 @@ const char* cmCacheManager::CacheIterator::GetProperty(const char* property) con
void cmCacheManager::CacheIterator::SetProperty(const char* p, const char* v)
{
+ // make sure it is not at the end
+ if (this->IsAtEnd())
+ {
+ return;
+ }
+
if ( !strcmp(p, "TYPE") || !strcmp(p, "VALUE") )
{
cmSystemTools::Error("Property \"", p,
@@ -664,6 +683,12 @@ void cmCacheManager::CacheIterator::SetProperty(const char* p, const char* v)
bool cmCacheManager::CacheIterator::GetPropertyAsBool(const char* property) const
{
+ // make sure it is not at the end
+ if (this->IsAtEnd())
+ {
+ return false;
+ }
+
if ( !strcmp(property, "TYPE") || !strcmp(property, "VALUE") )
{
cmSystemTools::Error("Property \"", property,
@@ -683,6 +708,12 @@ bool cmCacheManager::CacheIterator::GetPropertyAsBool(const char* property) cons
void cmCacheManager::CacheIterator::SetProperty(const char* p, bool v)
{
+ // make sure it is not at the end
+ if (this->IsAtEnd())
+ {
+ return;
+ }
+
if ( !strcmp(p, "TYPE") || !strcmp(p, "VALUE") )
{
cmSystemTools::Error("Property \"", p,
@@ -695,6 +726,12 @@ void cmCacheManager::CacheIterator::SetProperty(const char* p, bool v)
bool cmCacheManager::CacheIterator::PropertyExists(const char* property) const
{
+ // make sure it is not at the end
+ if (this->IsAtEnd())
+ {
+ return false;
+ }
+
if ( !strcmp(property, "TYPE") || !strcmp(property, "VALUE") )
{
cmSystemTools::Error("Property \"", property,
diff --git a/Source/cmCacheManager.h b/Source/cmCacheManager.h
index d79db99..6ead922 100644
--- a/Source/cmCacheManager.h
+++ b/Source/cmCacheManager.h
@@ -47,7 +47,7 @@ public:
public:
void Begin();
bool Find(const char*);
- bool IsAtEnd();
+ bool IsAtEnd() const;
void Next();
const char *GetName() const {
return m_Position->first.c_str(); }