mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-26 15:49:50 -06:00
wxWidgets3: update to svn r70933
This commit is contained in:
32
Externals/wxWidgets3/include/wx/hashmap.h
vendored
32
Externals/wxWidgets3/include/wx/hashmap.h
vendored
@ -4,7 +4,7 @@
|
||||
// Author: Mattia Barbon
|
||||
// Modified by:
|
||||
// Created: 29/01/2002
|
||||
// RCS-ID: $Id: hashmap.h 66711 2011-01-19 10:47:49Z VZ $
|
||||
// RCS-ID: $Id: hashmap.h 69568 2011-10-27 22:26:10Z VZ $
|
||||
// Copyright: (c) Mattia Barbon
|
||||
// Licence: wxWindows licence
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
@ -15,9 +15,9 @@
|
||||
#include "wx/string.h"
|
||||
#include "wx/wxcrt.h"
|
||||
|
||||
// In wxUSE_STL build we prefer to use the standard hash map class but it can
|
||||
// be either in non-standard hash_map header (old g++ and some other STL
|
||||
// implementations) or in C++0x standard unordered_map which can in turn be
|
||||
// In wxUSE_STD_CONTAINERS build we prefer to use the standard hash map class
|
||||
// but it can be either in non-standard hash_map header (old g++ and some other
|
||||
// STL implementations) or in C++0x standard unordered_map which can in turn be
|
||||
// available either in std::tr1 or std namespace itself
|
||||
//
|
||||
// To summarize: if std::unordered_map is available use it, otherwise use tr1
|
||||
@ -28,7 +28,7 @@
|
||||
#define HAVE_STL_HASH_MAP
|
||||
#endif
|
||||
|
||||
#if wxUSE_STL && \
|
||||
#if wxUSE_STD_CONTAINERS && \
|
||||
(defined(HAVE_STD_UNORDERED_MAP) || defined(HAVE_TR1_UNORDERED_MAP))
|
||||
|
||||
#if defined(HAVE_STD_UNORDERED_MAP)
|
||||
@ -42,7 +42,7 @@
|
||||
#define _WX_DECLARE_HASH_MAP( KEY_T, VALUE_T, HASH_T, KEY_EQ_T, CLASSNAME, CLASSEXP ) \
|
||||
typedef WX_HASH_MAP_NAMESPACE::unordered_map< KEY_T, VALUE_T, HASH_T, KEY_EQ_T > CLASSNAME
|
||||
|
||||
#elif wxUSE_STL && defined(HAVE_STL_HASH_MAP)
|
||||
#elif wxUSE_STD_CONTAINERS && defined(HAVE_STL_HASH_MAP)
|
||||
|
||||
#if defined(HAVE_EXT_HASH_MAP)
|
||||
#include <ext/hash_map>
|
||||
@ -59,7 +59,7 @@
|
||||
#define _WX_DECLARE_HASH_MAP( KEY_T, VALUE_T, HASH_T, KEY_EQ_T, CLASSNAME, CLASSEXP ) \
|
||||
typedef WX_HASH_MAP_NAMESPACE::hash_map< KEY_T, VALUE_T, HASH_T, KEY_EQ_T > CLASSNAME
|
||||
|
||||
#else // !wxUSE_STL || no std::{hash,unordered}_map class available
|
||||
#else // !wxUSE_STD_CONTAINERS || no std::{hash,unordered}_map class available
|
||||
|
||||
#define wxNEEDS_WX_HASH_MAP
|
||||
|
||||
@ -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 \
|
||||
{ \
|
||||
public: \
|
||||
@ -217,7 +219,7 @@ public: \
|
||||
iterator& operator++() { PlusPlus(); return *this; } \
|
||||
iterator operator++(int) { iterator it=*this;PlusPlus();return it; } \
|
||||
reference operator *() const { return m_node->m_value; } \
|
||||
pointer operator ->() const { return &(m_node->m_value); } \
|
||||
PTROPERATOR(pointer) \
|
||||
}; \
|
||||
\
|
||||
CLASSEXP const_iterator : public Iterator \
|
||||
@ -230,7 +232,7 @@ public: \
|
||||
const_iterator& operator++() { PlusPlus();return *this; } \
|
||||
const_iterator operator++(int) { const_iterator it=*this;PlusPlus();return it; } \
|
||||
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(), \
|
||||
@ -632,10 +634,16 @@ public:
|
||||
|
||||
#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 ) \
|
||||
_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_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 \
|
||||
{ \
|
||||
public: \
|
||||
@ -676,7 +684,7 @@ public: \
|
||||
\
|
||||
size_type erase( const key_type& 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 */ \
|
||||
size_type count( const const_key_type& key ) \
|
||||
|
Reference in New Issue
Block a user