williamr@2
|
1 |
//
|
williamr@2
|
2 |
// Boost.Pointer Container
|
williamr@2
|
3 |
//
|
williamr@2
|
4 |
// Copyright Thorsten Ottosen 2003-2005. Use, modification and
|
williamr@2
|
5 |
// distribution is subject to the Boost Software License, Version
|
williamr@2
|
6 |
// 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
williamr@2
|
7 |
// http://www.boost.org/LICENSE_1_0.txt)
|
williamr@2
|
8 |
//
|
williamr@2
|
9 |
// For more information, see http://www.boost.org/libs/ptr_container/
|
williamr@2
|
10 |
//
|
williamr@2
|
11 |
|
williamr@2
|
12 |
#ifndef BOOST_PTR_CONTAINER_PTR_SET_HPP
|
williamr@2
|
13 |
#define BOOST_PTR_CONTAINER_PTR_SET_HPP
|
williamr@2
|
14 |
|
williamr@2
|
15 |
#if defined(_MSC_VER) && (_MSC_VER >= 1200)
|
williamr@2
|
16 |
# pragma once
|
williamr@2
|
17 |
#endif
|
williamr@2
|
18 |
|
williamr@2
|
19 |
#include <boost/ptr_container/indirect_fun.hpp>
|
williamr@2
|
20 |
#include <boost/ptr_container/ptr_set_adapter.hpp>
|
williamr@2
|
21 |
#include <set>
|
williamr@2
|
22 |
|
williamr@2
|
23 |
namespace boost
|
williamr@2
|
24 |
{
|
williamr@2
|
25 |
|
williamr@2
|
26 |
template
|
williamr@2
|
27 |
<
|
williamr@2
|
28 |
class Key,
|
williamr@2
|
29 |
class Compare = std::less<Key>,
|
williamr@2
|
30 |
class CloneAllocator = heap_clone_allocator,
|
williamr@2
|
31 |
class Allocator = std::allocator<void*>
|
williamr@2
|
32 |
>
|
williamr@2
|
33 |
class ptr_set :
|
williamr@2
|
34 |
public ptr_set_adapter< Key,
|
williamr@2
|
35 |
std::set<void*,void_ptr_indirect_fun<Compare,Key>,Allocator>,
|
williamr@2
|
36 |
CloneAllocator >
|
williamr@2
|
37 |
{
|
williamr@2
|
38 |
typedef ptr_set_adapter< Key, std::set<void*,void_ptr_indirect_fun<Compare,Key>,Allocator>,
|
williamr@2
|
39 |
CloneAllocator >
|
williamr@2
|
40 |
base_type;
|
williamr@2
|
41 |
|
williamr@2
|
42 |
typedef ptr_set<Key,Compare,CloneAllocator,Allocator> this_type;
|
williamr@2
|
43 |
|
williamr@2
|
44 |
public:
|
williamr@2
|
45 |
explicit ptr_set( const Compare& comp = Compare(),
|
williamr@2
|
46 |
const Allocator& a = Allocator() )
|
williamr@2
|
47 |
: base_type( comp, a )
|
williamr@2
|
48 |
{ }
|
williamr@2
|
49 |
|
williamr@2
|
50 |
template< typename InputIterator >
|
williamr@2
|
51 |
ptr_set( InputIterator first, InputIterator last,
|
williamr@2
|
52 |
const Compare& comp = Compare(),
|
williamr@2
|
53 |
const Allocator& a = Allocator() )
|
williamr@2
|
54 |
: base_type( first, last, comp, a )
|
williamr@2
|
55 |
{ }
|
williamr@2
|
56 |
|
williamr@2
|
57 |
BOOST_PTR_CONTAINER_DEFINE_RELEASE_AND_CLONE( ptr_set,
|
williamr@2
|
58 |
base_type,
|
williamr@2
|
59 |
this_type );
|
williamr@2
|
60 |
|
williamr@2
|
61 |
};
|
williamr@2
|
62 |
|
williamr@2
|
63 |
|
williamr@2
|
64 |
|
williamr@2
|
65 |
template
|
williamr@2
|
66 |
<
|
williamr@2
|
67 |
class Key,
|
williamr@2
|
68 |
class Compare = std::less<Key>,
|
williamr@2
|
69 |
class CloneAllocator = heap_clone_allocator,
|
williamr@2
|
70 |
class Allocator = std::allocator<void*>
|
williamr@2
|
71 |
>
|
williamr@2
|
72 |
class ptr_multiset :
|
williamr@2
|
73 |
public ptr_multiset_adapter< Key,
|
williamr@2
|
74 |
std::multiset<void*,void_ptr_indirect_fun<Compare,Key>,Allocator>,
|
williamr@2
|
75 |
CloneAllocator >
|
williamr@2
|
76 |
{
|
williamr@2
|
77 |
typedef ptr_multiset_adapter< Key,
|
williamr@2
|
78 |
std::multiset<void*,void_ptr_indirect_fun<Compare,Key>,Allocator>,
|
williamr@2
|
79 |
CloneAllocator >
|
williamr@2
|
80 |
base_type;
|
williamr@2
|
81 |
typedef ptr_multiset<Key,Compare,CloneAllocator,Allocator> this_type;
|
williamr@2
|
82 |
|
williamr@2
|
83 |
public:
|
williamr@2
|
84 |
explicit ptr_multiset( const Compare& comp = Compare(),
|
williamr@2
|
85 |
const Allocator& a = Allocator() )
|
williamr@2
|
86 |
: base_type( comp, a )
|
williamr@2
|
87 |
{ }
|
williamr@2
|
88 |
|
williamr@2
|
89 |
template< typename InputIterator >
|
williamr@2
|
90 |
ptr_multiset( InputIterator first, InputIterator last,
|
williamr@2
|
91 |
const Compare& comp = Compare(),
|
williamr@2
|
92 |
const Allocator& a = Allocator() )
|
williamr@2
|
93 |
: base_type( first, last, comp, a )
|
williamr@2
|
94 |
{ }
|
williamr@2
|
95 |
|
williamr@2
|
96 |
BOOST_PTR_CONTAINER_DEFINE_RELEASE_AND_CLONE( ptr_multiset,
|
williamr@2
|
97 |
base_type,
|
williamr@2
|
98 |
this_type );
|
williamr@2
|
99 |
|
williamr@2
|
100 |
};
|
williamr@2
|
101 |
|
williamr@2
|
102 |
/////////////////////////////////////////////////////////////////////////
|
williamr@2
|
103 |
// clonability
|
williamr@2
|
104 |
|
williamr@2
|
105 |
template< typename K, typename C, typename CA, typename A >
|
williamr@2
|
106 |
inline ptr_set<K,C,CA,A>* new_clone( const ptr_set<K,C,CA,A>& r )
|
williamr@2
|
107 |
{
|
williamr@2
|
108 |
return r.clone().release();
|
williamr@2
|
109 |
}
|
williamr@2
|
110 |
|
williamr@2
|
111 |
template< typename K, typename C, typename CA, typename A >
|
williamr@2
|
112 |
inline ptr_multiset<K,C,CA,A>* new_clone( const ptr_multiset<K,C,CA,A>& r )
|
williamr@2
|
113 |
{
|
williamr@2
|
114 |
return r.clone().release();
|
williamr@2
|
115 |
}
|
williamr@2
|
116 |
|
williamr@2
|
117 |
/////////////////////////////////////////////////////////////////////////
|
williamr@2
|
118 |
// swap
|
williamr@2
|
119 |
|
williamr@2
|
120 |
template< typename K, typename C, typename CA, typename A >
|
williamr@2
|
121 |
inline void swap( ptr_set<K,C,CA,A>& l, ptr_set<K,C,CA,A>& r )
|
williamr@2
|
122 |
{
|
williamr@2
|
123 |
l.swap(r);
|
williamr@2
|
124 |
}
|
williamr@2
|
125 |
|
williamr@2
|
126 |
template< typename K, typename C, typename CA, typename A >
|
williamr@2
|
127 |
inline void swap( ptr_multiset<K,C,CA,A>& l, ptr_multiset<K,C,CA,A>& r )
|
williamr@2
|
128 |
{
|
williamr@2
|
129 |
l.swap(r);
|
williamr@2
|
130 |
}
|
williamr@2
|
131 |
|
williamr@2
|
132 |
}
|
williamr@2
|
133 |
|
williamr@2
|
134 |
#endif
|