-// macro implements remaining (not inline) methods of template list
-// (it's private to this file)
-#define _DEFINE_LIST(T, name) \
-name::~name() \
-{ \
- Empty(); \
-} \
- \
-void name::DoCopy(const name& src) \
-{ \
- for ( uint ui = 0; ui < src.Count(); ui++ ) \
- Add(src[ui]); \
-} \
- \
-name& name::operator=(const name& src) \
-{ \
- Empty(); \
- DoCopy(src); \
- \
- return *this; \
-} \
- \
-name::name(const name& src) \
-{ \
- DoCopy(src); \
-} \
- \
-void name::Empty() \
-{ \
- for ( uint ui = 0; ui < Count(); ui++ ) \
- delete (T*)BaseArray::Item(ui); \
- \
- BaseArray::Clear(); \
-} \
- \
-void name::Remove(uint uiIndex) \
-{ \
- wxCHECK( uiIndex < Count() ); \
- \
- delete (T*)BaseArray::Item(uiIndex); \
- \
- BaseArray::Remove(uiIndex); \
-} \
- \
-void name::Add(const T& item) \
-{ \
- T* pItem = new T(item); \
- if ( pItem != NULL ) \
- Add(pItem); \
-} \
- \
-void name::Insert(const T& item, uint uiIndex) \
-{ \
- T* pItem = new T(item); \
- if ( pItem != NULL ) \
- Insert(pItem, uiIndex); \
-} \
- \
-int name::Index(const T& Item, Bool bFromEnd) const \
-{ \
- if ( bFromEnd ) { \
- if ( Count() > 0 ) { \
- uint ui = Count() - 1; \
- do { \
- if ( (T*)BaseArray::Item(ui) == &Item ) \
- return ui; \
- ui--; \
- } \
- while ( ui != 0 ); \
- } \
- } \
- else { \
- for( uint ui = 0; ui < Count(); ui++ ) { \
- if( (T*)BaseArray::Item(ui) == &Item ) \
- return ui; \
- } \
- } \
- \
- return NOT_FOUND; \
-}