1998-11-24 23:34:24 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: listimpl.cpp
|
|
|
|
// Purpose: helper file for implementation of dynamic lists
|
|
|
|
// Author: Vadim Zeitlin
|
1999-10-04 20:15:38 +00:00
|
|
|
// Modified by:
|
1998-11-24 23:34:24 +00:00
|
|
|
// Created: 16.10.97
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) 1997 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
|
|
|
|
// Licence: wxWindows license
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
* Purpose: implements methods of "template" class declared in *
|
|
|
|
* DECLARE_OBJARRAY macro and which couldn't be implemented inline *
|
|
|
|
* (because they need the full definition of type T in scope) *
|
|
|
|
* *
|
|
|
|
* Usage: 1) #include dynarray.h *
|
|
|
|
* 2) WX_DECLARE_OBJARRAY *
|
|
|
|
* 3) #include arrimpl.cpp *
|
|
|
|
* 4) WX_DEFINE_OBJARRAY *
|
|
|
|
*****************************************************************************/
|
|
|
|
|
1999-10-04 20:15:38 +00:00
|
|
|
// needed to resolve the conflict between global T and macro parameter T
|
1999-11-16 13:28:23 +00:00
|
|
|
#define _WX_ERROR_REMOVE2(x) wxT("bad index in " #x "::RemoveAt()")
|
1999-10-04 20:15:38 +00:00
|
|
|
|
1998-11-24 23:34:24 +00:00
|
|
|
// macro implements remaining (not inline) methods of template list
|
|
|
|
// (it's private to this file)
|
1999-01-09 00:29:40 +00:00
|
|
|
#undef _DEFINE_OBJARRAY
|
|
|
|
#define _DEFINE_OBJARRAY(T, name) \
|
1998-11-24 23:34:24 +00:00
|
|
|
name::~name() \
|
|
|
|
{ \
|
|
|
|
Empty(); \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
void name::DoCopy(const name& src) \
|
|
|
|
{ \
|
1999-01-09 00:29:40 +00:00
|
|
|
for ( size_t ui = 0; ui < src.Count(); ui++ ) \
|
1998-11-24 23:34:24 +00:00
|
|
|
Add(src[ui]); \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
name& name::operator=(const name& src) \
|
|
|
|
{ \
|
|
|
|
Empty(); \
|
|
|
|
DoCopy(src); \
|
|
|
|
\
|
|
|
|
return *this; \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
name::name(const name& src) \
|
|
|
|
{ \
|
|
|
|
DoCopy(src); \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
void name::Empty() \
|
|
|
|
{ \
|
1999-01-09 00:29:40 +00:00
|
|
|
for ( size_t ui = 0; ui < Count(); ui++ ) \
|
|
|
|
delete (T*)wxBaseArray::Item(ui); \
|
1998-11-24 23:34:24 +00:00
|
|
|
\
|
1999-01-09 00:29:40 +00:00
|
|
|
wxBaseArray::Clear(); \
|
1998-11-24 23:34:24 +00:00
|
|
|
} \
|
|
|
|
\
|
1999-11-16 13:28:23 +00:00
|
|
|
void name::RemoveAt(size_t uiIndex) \
|
1998-11-24 23:34:24 +00:00
|
|
|
{ \
|
1999-10-04 20:15:38 +00:00
|
|
|
wxCHECK_RET( uiIndex < Count(), _WX_ERROR_REMOVE2(name) ); \
|
1998-11-24 23:34:24 +00:00
|
|
|
\
|
1999-01-09 00:29:40 +00:00
|
|
|
delete (T*)wxBaseArray::Item(uiIndex); \
|
1998-11-24 23:34:24 +00:00
|
|
|
\
|
1999-11-16 13:28:23 +00:00
|
|
|
wxBaseArray::RemoveAt(uiIndex); \
|
1998-11-24 23:34:24 +00:00
|
|
|
} \
|
|
|
|
\
|
|
|
|
void name::Add(const T& item) \
|
|
|
|
{ \
|
|
|
|
T* pItem = new T(item); \
|
|
|
|
if ( pItem != NULL ) \
|
|
|
|
Add(pItem); \
|
|
|
|
} \
|
|
|
|
\
|
1999-01-09 00:29:40 +00:00
|
|
|
void name::Insert(const T& item, size_t uiIndex) \
|
1998-11-24 23:34:24 +00:00
|
|
|
{ \
|
|
|
|
T* pItem = new T(item); \
|
|
|
|
if ( pItem != NULL ) \
|
|
|
|
Insert(pItem, uiIndex); \
|
|
|
|
} \
|
|
|
|
\
|
1999-01-09 00:29:40 +00:00
|
|
|
int name::Index(const T& Item, bool bFromEnd) const \
|
1998-11-24 23:34:24 +00:00
|
|
|
{ \
|
|
|
|
if ( bFromEnd ) { \
|
|
|
|
if ( Count() > 0 ) { \
|
1999-01-09 00:29:40 +00:00
|
|
|
size_t ui = Count() - 1; \
|
1998-11-24 23:34:24 +00:00
|
|
|
do { \
|
1999-01-09 00:29:40 +00:00
|
|
|
if ( (T*)wxBaseArray::Item(ui) == &Item ) \
|
1998-11-24 23:34:24 +00:00
|
|
|
return ui; \
|
|
|
|
ui--; \
|
|
|
|
} \
|
|
|
|
while ( ui != 0 ); \
|
|
|
|
} \
|
|
|
|
} \
|
|
|
|
else { \
|
1999-01-09 00:29:40 +00:00
|
|
|
for( size_t ui = 0; ui < Count(); ui++ ) { \
|
|
|
|
if( (T*)wxBaseArray::Item(ui) == &Item ) \
|
1998-11-24 23:34:24 +00:00
|
|
|
return ui; \
|
|
|
|
} \
|
|
|
|
} \
|
|
|
|
\
|
1999-10-04 20:15:38 +00:00
|
|
|
return wxNOT_FOUND; \
|
|
|
|
}
|
1998-11-24 23:34:24 +00:00
|
|
|
|
|
|
|
// redefine the macro so that now it will generate the class implementation
|
|
|
|
// old value would provoke a compile-time error if this file is not included
|
|
|
|
#undef WX_DEFINE_OBJARRAY
|
|
|
|
#define WX_DEFINE_OBJARRAY(name) _DEFINE_OBJARRAY(_L##name, name)
|