This commit is contained in:
dickelbeck 2008-12-02 18:20:49 +00:00
parent bcbcdebf39
commit 7de4bfe6e1
2 changed files with 44 additions and 4 deletions

View File

@ -135,7 +135,7 @@ void DHEAD::remove( EDA_BaseStruct* aElement )
{ {
aElement->Next()->SetBack( aElement->Back() ); aElement->Next()->SetBack( aElement->Back() );
} }
else else // element being removed is last
{ {
wxASSERT( last == aElement ); wxASSERT( last == aElement );
last = aElement->Back(); last = aElement->Back();
@ -143,9 +143,9 @@ void DHEAD::remove( EDA_BaseStruct* aElement )
if( aElement->Back() ) if( aElement->Back() )
{ {
aElement->Back()->SetNext( aElement->Back() ); aElement->Back()->SetNext( aElement->Next() );
} }
else else // element being removed is first
{ {
wxASSERT( first == aElement ); wxASSERT( first == aElement );
first = aElement->Next(); first = aElement->Next();
@ -156,5 +156,42 @@ void DHEAD::remove( EDA_BaseStruct* aElement )
aElement->SetList( 0 ); aElement->SetList( 0 );
--count; --count;
D( VerifyListIntegrity(); );
} }
#if defined(DEBUG)
void DHEAD::VerifyListIntegrity()
{
EDA_BaseStruct* item;
unsigned i = 0;
for( item = first; item && i<count; ++i, item = item->Next() )
{
if( i < count-1 )
{
wxASSERT( item->Next() );
}
wxASSERT( item->GetList() == this );
}
wxASSERT( item == NULL );
wxASSERT( i == count );
i = 0;
for( item = last; item && i<count; ++i, item = item->Back() )
{
if( i < count-1 )
{
wxASSERT( item->Back() );
}
}
wxASSERT( item == NULL );
wxASSERT( i == count );
}
#endif

View File

@ -108,6 +108,10 @@ public:
* returns the number of elements in the list. * returns the number of elements in the list.
*/ */
unsigned GetCount() { return count; } unsigned GetCount() { return count; }
#if defined(DEBUG)
void VerifyListIntegrity();
#endif
}; };
@ -179,7 +183,6 @@ public:
return aElement; return aElement;
} }
//-----< STL like functions >--------------------------------------- //-----< STL like functions >---------------------------------------
T* begin() const { return GetFirst(); } T* begin() const { return GetFirst(); }
T* end() const { return NULL; } T* end() const { return NULL; }