Add _PTR WX_DECLARE_HASH_SET variants to fix warnings about operator->().
Macros from WX_DECLARE_HASH_SET family could declare an operator->() which could never be called because it returned a pointer to a non-object (e.g. a pointer or a primitive type). Fix this in the same way as for WX_DECLARE_ARRAY macros by adding (badly but consistently) named _PTR variants of the macros to allow defining the versions without operator->(). This fixes tons of warnings when building wx with Sun CC. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@69568 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -127,7 +127,9 @@ protected:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#define _WX_DECLARE_HASHTABLE( VALUE_T, KEY_T, HASH_T, KEY_EX_T, KEY_EQ_T, CLASSNAME, CLASSEXP, SHOULD_GROW, SHOULD_SHRINK ) \
|
#define _WX_DECLARE_HASHTABLE( VALUE_T, KEY_T, HASH_T, KEY_EX_T, KEY_EQ_T,\
|
||||||
|
PTROPERATOR, CLASSNAME, CLASSEXP, \
|
||||||
|
SHOULD_GROW, SHOULD_SHRINK ) \
|
||||||
CLASSEXP CLASSNAME : protected _wxHashTableBase2 \
|
CLASSEXP CLASSNAME : protected _wxHashTableBase2 \
|
||||||
{ \
|
{ \
|
||||||
public: \
|
public: \
|
||||||
@@ -217,7 +219,7 @@ public: \
|
|||||||
iterator& operator++() { PlusPlus(); return *this; } \
|
iterator& operator++() { PlusPlus(); return *this; } \
|
||||||
iterator operator++(int) { iterator it=*this;PlusPlus();return it; } \
|
iterator operator++(int) { iterator it=*this;PlusPlus();return it; } \
|
||||||
reference operator *() const { return m_node->m_value; } \
|
reference operator *() const { return m_node->m_value; } \
|
||||||
pointer operator ->() const { return &(m_node->m_value); } \
|
PTROPERATOR(pointer) \
|
||||||
}; \
|
}; \
|
||||||
\
|
\
|
||||||
CLASSEXP const_iterator : public Iterator \
|
CLASSEXP const_iterator : public Iterator \
|
||||||
@@ -230,7 +232,7 @@ public: \
|
|||||||
const_iterator& operator++() { PlusPlus();return *this; } \
|
const_iterator& operator++() { PlusPlus();return *this; } \
|
||||||
const_iterator operator++(int) { const_iterator it=*this;PlusPlus();return it; } \
|
const_iterator operator++(int) { const_iterator it=*this;PlusPlus();return it; } \
|
||||||
const_reference operator *() const { return m_node->m_value; } \
|
const_reference operator *() const { return m_node->m_value; } \
|
||||||
const_pointer operator ->() const { return &(m_node->m_value); } \
|
PTROPERATOR(const_pointer) \
|
||||||
}; \
|
}; \
|
||||||
\
|
\
|
||||||
CLASSNAME( size_type sz = 10, const hasher& hfun = hasher(), \
|
CLASSNAME( size_type sz = 10, const hasher& hfun = hasher(), \
|
||||||
@@ -632,10 +634,16 @@ public:
|
|||||||
|
|
||||||
#ifdef wxNEEDS_WX_HASH_MAP
|
#ifdef wxNEEDS_WX_HASH_MAP
|
||||||
|
|
||||||
|
#define wxPTROP_NORMAL(pointer) \
|
||||||
|
pointer operator ->() const { return &(m_node->m_value); }
|
||||||
|
#define wxPTROP_NOP(pointer)
|
||||||
|
|
||||||
#define _WX_DECLARE_HASH_MAP( KEY_T, VALUE_T, HASH_T, KEY_EQ_T, CLASSNAME, CLASSEXP ) \
|
#define _WX_DECLARE_HASH_MAP( KEY_T, VALUE_T, HASH_T, KEY_EQ_T, CLASSNAME, CLASSEXP ) \
|
||||||
_WX_DECLARE_PAIR( KEY_T, VALUE_T, CLASSNAME##_wxImplementation_Pair, CLASSEXP ) \
|
_WX_DECLARE_PAIR( KEY_T, VALUE_T, CLASSNAME##_wxImplementation_Pair, CLASSEXP ) \
|
||||||
_WX_DECLARE_HASH_MAP_KEY_EX( KEY_T, CLASSNAME##_wxImplementation_Pair, CLASSNAME##_wxImplementation_KeyEx, CLASSEXP ) \
|
_WX_DECLARE_HASH_MAP_KEY_EX( KEY_T, CLASSNAME##_wxImplementation_Pair, CLASSNAME##_wxImplementation_KeyEx, CLASSEXP ) \
|
||||||
_WX_DECLARE_HASHTABLE( CLASSNAME##_wxImplementation_Pair, KEY_T, HASH_T, CLASSNAME##_wxImplementation_KeyEx, KEY_EQ_T, CLASSNAME##_wxImplementation_HashTable, CLASSEXP, grow_lf70, never_shrink ) \
|
_WX_DECLARE_HASHTABLE( CLASSNAME##_wxImplementation_Pair, KEY_T, HASH_T, \
|
||||||
|
CLASSNAME##_wxImplementation_KeyEx, KEY_EQ_T, wxPTROP_NORMAL, \
|
||||||
|
CLASSNAME##_wxImplementation_HashTable, CLASSEXP, grow_lf70, never_shrink ) \
|
||||||
CLASSEXP CLASSNAME:public CLASSNAME##_wxImplementation_HashTable \
|
CLASSEXP CLASSNAME:public CLASSNAME##_wxImplementation_HashTable \
|
||||||
{ \
|
{ \
|
||||||
public: \
|
public: \
|
||||||
@@ -676,7 +684,7 @@ public: \
|
|||||||
\
|
\
|
||||||
size_type erase( const key_type& k ) \
|
size_type erase( const key_type& k ) \
|
||||||
{ return CLASSNAME##_wxImplementation_HashTable::erase( k ); } \
|
{ return CLASSNAME##_wxImplementation_HashTable::erase( k ); } \
|
||||||
void erase( const iterator& it ) { erase( it->first ); } \
|
void erase( const iterator& it ) { erase( (*it).first ); } \
|
||||||
\
|
\
|
||||||
/* count() == 0 | 1 */ \
|
/* count() == 0 | 1 */ \
|
||||||
size_type count( const const_key_type& key ) \
|
size_type count( const const_key_type& key ) \
|
||||||
|
@@ -46,7 +46,7 @@
|
|||||||
|
|
||||||
// we need to define the class declared by _WX_DECLARE_HASH_SET as a class and
|
// we need to define the class declared by _WX_DECLARE_HASH_SET as a class and
|
||||||
// not a typedef to allow forward declaring it
|
// not a typedef to allow forward declaring it
|
||||||
#define _WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, CLASSEXP ) \
|
#define _WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, PTROP, CLASSNAME, CLASSEXP ) \
|
||||||
CLASSEXP CLASSNAME \
|
CLASSEXP CLASSNAME \
|
||||||
: public WX_HASH_SET_BASE_TEMPLATE< KEY_T, HASH_T, KEY_EQ_T > \
|
: public WX_HASH_SET_BASE_TEMPLATE< KEY_T, HASH_T, KEY_EQ_T > \
|
||||||
{ \
|
{ \
|
||||||
@@ -89,9 +89,11 @@ public: \
|
|||||||
CLASSNAME& operator=(const CLASSNAME&) { return *this; } \
|
CLASSNAME& operator=(const CLASSNAME&) { return *this; } \
|
||||||
};
|
};
|
||||||
|
|
||||||
#define _WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, CLASSEXP )\
|
#define _WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, PTROP, CLASSNAME, CLASSEXP )\
|
||||||
_WX_DECLARE_HASH_SET_KEY_EX( KEY_T, CLASSNAME##_wxImplementation_KeyEx, CLASSEXP ) \
|
_WX_DECLARE_HASH_SET_KEY_EX( KEY_T, CLASSNAME##_wxImplementation_KeyEx, CLASSEXP ) \
|
||||||
_WX_DECLARE_HASHTABLE( KEY_T, KEY_T, HASH_T, CLASSNAME##_wxImplementation_KeyEx, KEY_EQ_T, CLASSNAME##_wxImplementation_HashTable, CLASSEXP, grow_lf70, never_shrink ) \
|
_WX_DECLARE_HASHTABLE( KEY_T, KEY_T, HASH_T, \
|
||||||
|
CLASSNAME##_wxImplementation_KeyEx, KEY_EQ_T, PTROP, \
|
||||||
|
CLASSNAME##_wxImplementation_HashTable, CLASSEXP, grow_lf70, never_shrink ) \
|
||||||
CLASSEXP CLASSNAME:public CLASSNAME##_wxImplementation_HashTable \
|
CLASSEXP CLASSNAME:public CLASSNAME##_wxImplementation_HashTable \
|
||||||
{ \
|
{ \
|
||||||
public: \
|
public: \
|
||||||
@@ -134,17 +136,27 @@ public: \
|
|||||||
|
|
||||||
// these macros are to be used in the user code
|
// these macros are to be used in the user code
|
||||||
#define WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME) \
|
#define WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME) \
|
||||||
_WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, class )
|
_WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, wxPTROP_NORMAL, CLASSNAME, class )
|
||||||
|
|
||||||
// and these do exactly the same thing but should be used inside the
|
// and these do exactly the same thing but should be used inside the
|
||||||
// library
|
// library
|
||||||
#define WX_DECLARE_HASH_SET_WITH_DECL( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, DECL) \
|
#define WX_DECLARE_HASH_SET_WITH_DECL( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, DECL) \
|
||||||
_WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, DECL )
|
_WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, wxPTROP_NORMAL, CLASSNAME, DECL )
|
||||||
|
|
||||||
#define WX_DECLARE_EXPORTED_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME) \
|
#define WX_DECLARE_EXPORTED_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME) \
|
||||||
WX_DECLARE_HASH_SET_WITH_DECL( KEY_T, HASH_T, KEY_EQ_T, \
|
WX_DECLARE_HASH_SET_WITH_DECL( KEY_T, HASH_T, KEY_EQ_T, \
|
||||||
CLASSNAME, class WXDLLIMPEXP_CORE )
|
CLASSNAME, class WXDLLIMPEXP_CORE )
|
||||||
|
|
||||||
|
// Finally these versions allow to define hash sets of non-objects (including
|
||||||
|
// pointers, hence the confusing but wxArray-compatible name) without
|
||||||
|
// operator->() which can't be used for them. This is mostly used inside the
|
||||||
|
// library itself to avoid warnings when using such hash sets with some less
|
||||||
|
// common compilers (notably Sun CC).
|
||||||
|
#define WX_DECLARE_HASH_SET_PTR( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME) \
|
||||||
|
_WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, wxPTROP_NOP, CLASSNAME, class )
|
||||||
|
#define WX_DECLARE_HASH_SET_WITH_DECL_PTR( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, DECL) \
|
||||||
|
_WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, wxPTROP_NOP, CLASSNAME, DECL )
|
||||||
|
|
||||||
// delete all hash elements
|
// delete all hash elements
|
||||||
//
|
//
|
||||||
// NB: the class declaration of the hash elements must be visible from the
|
// NB: the class declaration of the hash elements must be visible from the
|
||||||
|
@@ -28,7 +28,7 @@ class WXDLLIMPEXP_FWD_HTML wxHtmlEntitiesParser;
|
|||||||
class wxHtmlTextPieces;
|
class wxHtmlTextPieces;
|
||||||
class wxHtmlParserState;
|
class wxHtmlParserState;
|
||||||
|
|
||||||
WX_DECLARE_HASH_SET_WITH_DECL(wxHtmlTagHandler*,
|
WX_DECLARE_HASH_SET_WITH_DECL_PTR(wxHtmlTagHandler*,
|
||||||
wxPointerHash, wxPointerEqual,
|
wxPointerHash, wxPointerEqual,
|
||||||
wxHtmlTagHandlersSet,
|
wxHtmlTagHandlersSet,
|
||||||
class WXDLLIMPEXP_HTML);
|
class WXDLLIMPEXP_HTML);
|
||||||
|
@@ -72,7 +72,7 @@ const char wxGridNameStr[] = "grid";
|
|||||||
// Required for wxIs... functions
|
// Required for wxIs... functions
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
WX_DECLARE_HASH_SET_WITH_DECL(int, wxIntegerHash, wxIntegerEqual,
|
WX_DECLARE_HASH_SET_WITH_DECL_PTR(int, wxIntegerHash, wxIntegerEqual,
|
||||||
wxGridFixedIndicesSet, class WXDLLIMPEXP_ADV);
|
wxGridFixedIndicesSet, class WXDLLIMPEXP_ADV);
|
||||||
|
|
||||||
|
|
||||||
|
@@ -103,7 +103,7 @@ class wxXmlResourceDataRecords : public wxVector<wxXmlResourceDataRecord*>
|
|||||||
// this is a class so that it can be forward-declared
|
// this is a class so that it can be forward-declared
|
||||||
};
|
};
|
||||||
|
|
||||||
WX_DECLARE_HASH_SET(int, wxIntegerHash, wxIntegerEqual, wxHashSetInt);
|
WX_DECLARE_HASH_SET_PTR(int, wxIntegerHash, wxIntegerEqual, wxHashSetInt);
|
||||||
|
|
||||||
class wxIdRange // Holds data for a particular rangename
|
class wxIdRange // Holds data for a particular rangename
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user