Files
boost_unordered/include/boost/unordered/detail/set.hpp

100 lines
3.5 KiB
C++
Raw Normal View History

// Copyright (C) 2005-2016 Daniel James
// Distributed under 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)
#include <boost/unordered/detail/implementation.hpp>
2017-02-19 13:05:17 +00:00
#include <boost/unordered/unordered_set_fwd.hpp>
2017-02-19 13:05:17 +00:00
namespace boost {
namespace unordered {
namespace detail {
template <typename A, typename T, typename H, typename P> struct set
{
typedef boost::unordered::detail::set<A, T, H, P> types;
2017-02-19 13:05:17 +00:00
typedef T value_type;
typedef H hasher;
typedef P key_equal;
2017-02-23 20:14:27 +00:00
typedef T const const_key_type;
2017-02-23 20:14:27 +00:00
typedef typename ::boost::unordered::detail::rebind_wrap<A,
value_type>::type value_allocator;
typedef boost::unordered::detail::allocator_traits<value_allocator>
value_allocator_traits;
typedef boost::unordered::detail::pick_node<A, value_type> pick;
2017-02-19 13:05:17 +00:00
typedef typename pick::node node;
typedef typename pick::bucket bucket;
typedef typename pick::link_pointer link_pointer;
2017-02-19 13:05:17 +00:00
typedef boost::unordered::detail::table_impl<types> table;
typedef boost::unordered::detail::set_extractor<value_type> extractor;
2017-02-19 13:05:17 +00:00
typedef typename boost::unordered::detail::pick_policy<T>::type policy;
2016-10-22 10:04:36 +01:00
2017-02-19 13:05:17 +00:00
typedef boost::unordered::iterator_detail::c_iterator<node> iterator;
typedef boost::unordered::iterator_detail::c_iterator<node> c_iterator;
typedef boost::unordered::iterator_detail::cl_iterator<node, policy>
l_iterator;
typedef boost::unordered::iterator_detail::cl_iterator<node, policy>
cl_iterator;
2017-02-27 03:59:02 +00:00
typedef boost::unordered::node_handle_set<node, T, A> node_type;
typedef boost::unordered::insert_return_type_set<node, T, A>
insert_return_type;
2017-02-19 13:05:17 +00:00
};
2017-02-19 13:05:17 +00:00
template <typename A, typename T, typename H, typename P> struct multiset
{
typedef boost::unordered::detail::multiset<A, T, H, P> types;
2017-02-19 13:05:17 +00:00
typedef T value_type;
typedef H hasher;
typedef P key_equal;
2017-02-23 20:14:27 +00:00
typedef T const const_key_type;
2017-02-23 20:14:27 +00:00
typedef typename ::boost::unordered::detail::rebind_wrap<A,
value_type>::type value_allocator;
typedef boost::unordered::detail::allocator_traits<value_allocator>
value_allocator_traits;
typedef boost::unordered::detail::pick_grouped_node<A, value_type> pick;
2017-02-19 13:05:17 +00:00
typedef typename pick::node node;
typedef typename pick::bucket bucket;
typedef typename pick::link_pointer link_pointer;
2017-02-19 13:05:17 +00:00
typedef boost::unordered::detail::grouped_table_impl<types> table;
typedef boost::unordered::detail::set_extractor<value_type> extractor;
2017-02-19 13:05:17 +00:00
typedef typename boost::unordered::detail::pick_policy<T>::type policy;
2016-10-22 10:04:36 +01:00
2017-02-19 13:05:17 +00:00
typedef boost::unordered::iterator_detail::c_iterator<node> iterator;
typedef boost::unordered::iterator_detail::c_iterator<node> c_iterator;
typedef boost::unordered::iterator_detail::cl_iterator<node, policy>
l_iterator;
typedef boost::unordered::iterator_detail::cl_iterator<node, policy>
cl_iterator;
2017-02-27 03:59:02 +00:00
typedef boost::unordered::node_handle_set<node, T, A> node_type;
};
template <typename T, typename H, typename P, typename A> class instantiate_set
{
typedef boost::unordered_set<T, H, P, A> container;
container x;
typename container::node_type node_type;
typename container::insert_return_type insert_return_type;
};
template <typename T, typename H, typename P, typename A>
class instantiate_multiset
{
typedef boost::unordered_multiset<T, H, P, A> container;
container x;
typename container::node_type node_type;
2017-02-19 13:05:17 +00:00
};
}
}
}