$include_dir="/home/hyper-archives/boost-commit/include"; include("$include_dir/msg-header.inc") ?>
From: nesotto_at_[hidden]
Date: 2008-06-04 11:31:13
Author: nesotto
Date: 2008-06-04 11:31:13 EDT (Wed, 04 Jun 2008)
New Revision: 46118
URL: http://svn.boost.org/trac/boost/changeset/46118
Log:
Update for unordered containers
Added:
   trunk/boost/ptr_container/ptr_unordered_map.hpp   (contents, props changed)
Added: trunk/boost/ptr_container/ptr_unordered_map.hpp
==============================================================================
--- (empty file)
+++ trunk/boost/ptr_container/ptr_unordered_map.hpp	2008-06-04 11:31:13 EDT (Wed, 04 Jun 2008)
@@ -0,0 +1,250 @@
+//
+// 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>
+
+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,void*> >
+    >
+    class ptr_unordered_map : 
+        public ptr_map_adapter<T,boost::unordered_map<Key,void*,Hash,Pred,Allocator>,
+                               CloneAllocator,false>
+    {
+        typedef ptr_map_adapter<T,boost::unordered_map<Key,void*,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 )
+        { }
+
+        template< class U >
+        ptr_unordered_map& operator=( const ptr_unordered_map<Key,U>& r )
+        {
+            base_type::operator=( 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 )
+        { }
+
+        template< class U >
+        ptr_unordered_multimap& operator=( const ptr_unordered_multimap<Key,U>& r )
+        {
+            base_type::operator=( 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);
+    }
+
+
+}
+
+#endif