123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261 |
- //
- // Boost.Pointer Container
- //
- // Copyright Thorsten Ottosen 2008. Use, modification and
- // distribution is subject to the Boost Software License, Version
- // 1.0. (See accompanying file LICENSE_1_0.txt or copy at
- // http://www.boost.org/LICENSE_1_0.txt)
- //
- // For more information, see http://www.boost.org/libs/ptr_container/
- //
- #ifndef BOOST_PTR_CONTAINER_PTR_UNORDERED_MAP_HPP
- #define BOOST_PTR_CONTAINER_PTR_UNORDERED_MAP_HPP
- #if defined(_MSC_VER) && (_MSC_VER >= 1200)
- # pragma once
- #endif
- #include <boost/unordered_map.hpp>
- #include <boost/ptr_container/ptr_map_adapter.hpp>
- #include <boost/ptr_container/detail/ptr_container_disable_deprecated.hpp>
- #if defined(BOOST_PTR_CONTAINER_DISABLE_DEPRECATED)
- #pragma GCC diagnostic push
- #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
- #endif
- namespace boost
- {
- template
- <
- class Key,
- class T,
- class Hash = boost::hash<Key>,
- class Pred = std::equal_to<Key>,
- class CloneAllocator = heap_clone_allocator,
- class Allocator = std::allocator< std::pair<const Key,
- typename ptr_container_detail::void_ptr<T>::type> >
- >
- class ptr_unordered_map :
- public ptr_map_adapter<T,boost::unordered_map<Key,
- typename ptr_container_detail::void_ptr<T>::type,Hash,Pred,Allocator>,
- CloneAllocator,false>
- {
- typedef ptr_map_adapter<T,boost::unordered_map<Key,
- typename ptr_container_detail::void_ptr<T>::type,Hash,Pred,Allocator>,
- CloneAllocator,false>
- base_type;
- typedef ptr_unordered_map<Key,T,Hash,Pred,CloneAllocator,Allocator> this_type;
- public:
- typedef typename base_type::size_type size_type;
- private:
- using base_type::lower_bound;
- using base_type::upper_bound;
- using base_type::rbegin;
- using base_type::rend;
- using base_type::crbegin;
- using base_type::crend;
- using base_type::key_comp;
- using base_type::value_comp;
- using base_type::front;
- using base_type::back;
- public:
- using base_type::begin;
- using base_type::end;
- using base_type::cbegin;
- using base_type::cend;
- using base_type::bucket_count;
- using base_type::max_bucket_count;
- using base_type::bucket_size;
- using base_type::bucket;
- using base_type::load_factor;
- using base_type::max_load_factor;
- using base_type::rehash;
- using base_type::key_eq;
- using base_type::hash_function;
- public:
- ptr_unordered_map()
- { }
- explicit ptr_unordered_map( size_type n )
- : base_type( n, ptr_container_detail::unordered_associative_container_tag() )
- { }
- ptr_unordered_map( size_type n,
- const Hash& comp,
- const Pred& pred = Pred(),
- const Allocator& a = Allocator() )
- : base_type( n, comp, pred, a )
- { }
- template< typename InputIterator >
- ptr_unordered_map( InputIterator first, InputIterator last )
- : base_type( first, last )
- { }
- template< typename InputIterator >
- ptr_unordered_map( InputIterator first, InputIterator last,
- const Hash& comp,
- const Pred& pred = Pred(),
- const Allocator& a = Allocator() )
- : base_type( first, last, comp, pred, a )
- { }
- BOOST_PTR_CONTAINER_DEFINE_RELEASE_AND_CLONE( ptr_unordered_map,
- base_type,
- this_type )
- template< class U >
- ptr_unordered_map( const ptr_unordered_map<Key,U>& r ) : base_type( r )
- { }
- ptr_unordered_map& operator=( ptr_unordered_map r )
- {
- this->swap( r );
- return *this;
- }
- };
- template
- <
- class Key,
- class T,
- class Hash = boost::hash<Key>,
- class Pred = std::equal_to<Key>,
- class CloneAllocator = heap_clone_allocator,
- class Allocator = std::allocator< std::pair<const Key,void*> >
- >
- class ptr_unordered_multimap :
- public ptr_multimap_adapter<T,boost::unordered_multimap<Key,void*,Hash,Pred,Allocator>,
- CloneAllocator,false>
- {
- typedef ptr_multimap_adapter<T,boost::unordered_multimap<Key,void*,Hash,Pred,Allocator>,
- CloneAllocator,false>
- base_type;
- typedef ptr_unordered_multimap<Key,T,Hash,Pred,CloneAllocator,Allocator> this_type;
- public:
- typedef typename base_type::size_type size_type;
- private:
- using base_type::lower_bound;
- using base_type::upper_bound;
- using base_type::rbegin;
- using base_type::rend;
- using base_type::crbegin;
- using base_type::crend;
- using base_type::key_comp;
- using base_type::value_comp;
- using base_type::front;
- using base_type::back;
- public:
- using base_type::begin;
- using base_type::end;
- using base_type::cbegin;
- using base_type::cend;
- using base_type::bucket_count;
- using base_type::max_bucket_count;
- using base_type::bucket_size;
- using base_type::bucket;
- using base_type::load_factor;
- using base_type::max_load_factor;
- using base_type::rehash;
- using base_type::key_eq;
- using base_type::hash_function;
- public:
- ptr_unordered_multimap()
- { }
- explicit ptr_unordered_multimap( size_type n )
- : base_type( n, ptr_container_detail::unordered_associative_container_tag() )
- { }
- ptr_unordered_multimap( size_type n,
- const Hash& comp,
- const Pred& pred = Pred(),
- const Allocator& a = Allocator() )
- : base_type( n, comp, pred, a )
- { }
- template< typename InputIterator >
- ptr_unordered_multimap( InputIterator first, InputIterator last )
- : base_type( first, last )
- { }
- template< typename InputIterator >
- ptr_unordered_multimap( InputIterator first, InputIterator last,
- const Hash& comp,
- const Pred& pred = Pred(),
- const Allocator& a = Allocator() )
- : base_type( first, last, comp, pred, a )
- { }
- BOOST_PTR_CONTAINER_DEFINE_RELEASE_AND_CLONE( ptr_unordered_multimap,
- base_type,
- this_type )
- template< class U >
- ptr_unordered_multimap( const ptr_unordered_multimap<Key,U>& r ) : base_type( r )
- { }
- ptr_unordered_multimap& operator=( ptr_unordered_multimap r )
- {
- this->swap( r );
- return *this;
- }
- };
- //////////////////////////////////////////////////////////////////////////////
- // clonability
- template< class K, class T, class H, class P, class CA, class A >
- inline ptr_unordered_map<K,T,H,P,CA,A>*
- new_clone( const ptr_unordered_map<K,T,H,P,CA,A>& r )
- {
- return r.clone().release();
- }
- template< class K, class T, class H, class P, class CA, class A >
- inline ptr_unordered_multimap<K,T,H,P,CA,A>*
- new_clone( const ptr_unordered_multimap<K,T,H,P,CA,A>& r )
- {
- return r.clone().release();
- }
- /////////////////////////////////////////////////////////////////////////
- // swap
- template< class K, class T, class H, class P, class CA, class A >
- inline void swap( ptr_unordered_map<K,T,H,P,CA,A>& l,
- ptr_unordered_map<K,T,H,P,CA,A>& r )
- {
- l.swap(r);
- }
- template< class K, class T, class H, class P, class CA, class A >
- inline void swap( ptr_unordered_multimap<K,T,H,P,CA,A>& l,
- ptr_unordered_multimap<K,T,H,P,CA,A>& r )
- {
- l.swap(r);
- }
- }
- #if defined(BOOST_PTR_CONTAINER_DISABLE_DEPRECATED)
- #pragma GCC diagnostic pop
- #endif
- #endif
|