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,10 +28,10 @@ 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); | ||||||
| WX_DECLARE_STRING_HASH_MAP_WITH_DECL(wxHtmlTagHandler*, | WX_DECLARE_STRING_HASH_MAP_WITH_DECL(wxHtmlTagHandler*, | ||||||
|                                      wxHtmlTagHandlersHash, |                                      wxHtmlTagHandlersHash, | ||||||
|                                      class WXDLLIMPEXP_HTML); |                                      class WXDLLIMPEXP_HTML); | ||||||
|   | |||||||
| @@ -72,8 +72,8 @@ 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