From 4539c8c41709f87ccd15bfe54d2baa6e7464bda9 Mon Sep 17 00:00:00 2001 From: dickelbeck Date: Mon, 24 Nov 2008 07:30:11 +0000 Subject: [PATCH] better type safety on list Insert(), Remove(), Append() --- include/dlist.h | 71 ++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 56 insertions(+), 15 deletions(-) diff --git a/include/dlist.h b/include/dlist.h index d68d19e34f..6abb76b1e8 100644 --- a/include/dlist.h +++ b/include/dlist.h @@ -57,21 +57,6 @@ protected: ~DHEAD(); -public: - - /** - * Function DestructAll - * deletes all items on the list and leaves the list empty. - */ - void DestructAll(); - - /** - * Function SetOwnership - * controls whether the list owns the objects and is responsible for - * deleteing their memory at time of this object's destruction. - */ - void SetOwnership( bool Iown ) { meOwner = Iown; } - /** * Function Append * adds \a aNewElement to the end of the list. @@ -100,6 +85,23 @@ public: */ void Remove( EDA_BaseStruct* aElement ); + +public: + + /** + * Function DestructAll + * deletes all items on the list and leaves the list empty. + */ + void DestructAll(); + + /** + * Function SetOwnership + * controls whether the list owns the objects and is responsible for + * deleteing their memory at time of this object's destruction. + */ + void SetOwnership( bool Iown ) { meOwner = Iown; } + + /** * Function GetCount * returns the number of elements in the list. @@ -137,6 +139,45 @@ public: * returns the last T* in the list, or NULL if the list is empty. */ T* GetLast() const { return (T*) last; } + + + /** + * Function Append + * adds \a aNewElement to the end of the list. + */ + void Append( T* aNewElement ) + { + DHEAD::Append( aNewElement ); + } + + /** + * Function Insert + * puts aNewElement just in front of aElementAfterMe in the list sequence. + * If aElementAfterMe is NULL, then simply Append() + */ + void Insert( T* aNewElement, T* aElementAfterMe ) + { + DHEAD::Insert( aNewElement, aElementAfterMe ); + } + + /** + * Function Insert + * puts aNewElement in front of list sequence. + */ + void Insert( T* aNewElement ) + { + DHEAD::Insert( aNewElement ); + } + + /** + * Function Remove + * removes \a aElement from the list, but does not delete it. + */ + void Remove( T* aElement ) + { + DHEAD::Remove( aElement ); + } + }; #endif // DLIST_H_