don't use invalid/uninitialized iterator in wxList::compatibility_iterator in wxUSE_STL==1 case, this doesn't work with the debug version of glibc STL
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@38893 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -136,7 +136,7 @@ private:
|
||||
#endif // defined( __VISUALC__ )
|
||||
|
||||
/*
|
||||
Note: the outer helper class _WX_LIST_HELPER_##liT below is a workaround
|
||||
Note 1: the outer helper class _WX_LIST_HELPER_##liT below is a workaround
|
||||
for mingw 3.2.3 compiler bug that prevents a static function of liT class
|
||||
from being exported into dll. A minimal code snippet reproducing the bug:
|
||||
|
||||
@@ -155,6 +155,13 @@ private:
|
||||
|
||||
The program does not link under mingw_gcc 3.2.3 producing undefined
|
||||
reference to Foo::Bar() function
|
||||
|
||||
|
||||
Note 2: the EmptyList is needed to allow having a NULL pointer-like
|
||||
invalid iterator. We used to use just an uninitialized iterator object
|
||||
instead but this fails with some debug/checked versions of STL, notably the
|
||||
glibc version activated with _GLIBCXX_DEBUG, so we need to have a separate
|
||||
invalid iterator.
|
||||
*/
|
||||
|
||||
// the real wxList-class declaration
|
||||
@@ -170,6 +177,9 @@ private:
|
||||
decl liT : public std::list<elT> \
|
||||
{ \
|
||||
private: \
|
||||
typedef std::list<elT> BaseListType; \
|
||||
static BaseListType EmptyList; \
|
||||
\
|
||||
bool m_destroy; \
|
||||
public: \
|
||||
decl compatibility_iterator \
|
||||
@@ -183,7 +193,7 @@ private:
|
||||
liT * m_list; \
|
||||
public: \
|
||||
compatibility_iterator() \
|
||||
: m_iter(), m_list( NULL ) {} \
|
||||
: m_iter(EmptyList.end()), m_list( NULL ) {} \
|
||||
compatibility_iterator( liT* li, iterator i ) \
|
||||
: m_iter( i ), m_list( li ) {} \
|
||||
compatibility_iterator( const liT* li, iterator i ) \
|
||||
|
@@ -11,14 +11,15 @@
|
||||
|
||||
#if wxUSE_STL
|
||||
|
||||
#undef WX_DEFINE_LIST
|
||||
#define WX_DEFINE_LIST(name) \
|
||||
void _WX_LIST_HELPER_##name::DeleteFunction( _WX_LIST_ITEM_TYPE_##name X ) \
|
||||
#undef WX_DEFINE_LIST
|
||||
#define WX_DEFINE_LIST(name) \
|
||||
void _WX_LIST_HELPER_##name::DeleteFunction( _WX_LIST_ITEM_TYPE_##name X )\
|
||||
{ \
|
||||
delete X; \
|
||||
}
|
||||
} \
|
||||
name::BaseListType name::EmptyList;
|
||||
|
||||
#else // if !wxUSE_STL
|
||||
#else // !wxUSE_STL
|
||||
|
||||
#define _DEFINE_LIST(T, name) \
|
||||
void wx##name##Node::DeleteData() \
|
||||
@@ -34,5 +35,5 @@
|
||||
// don't pollute preprocessor's name space
|
||||
//#undef _DEFINE_LIST
|
||||
|
||||
#endif
|
||||
#endif // wxUSE_STL/!wxUSE_STL
|
||||
|
||||
|
Reference in New Issue
Block a user