2016-08-14 20:55:40 +01:00
|
|
|
|
|
|
|
// 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)
|
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
#include <boost/unordered/detail/implementation.hpp>
|
2017-02-19 13:05:17 +00:00
|
|
|
#include <boost/unordered/unordered_map_fwd.hpp>
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
namespace boost {
|
|
|
|
namespace unordered {
|
|
|
|
namespace detail {
|
|
|
|
template <typename A, typename K, typename M, typename H, typename P> struct map
|
|
|
|
{
|
|
|
|
typedef boost::unordered::detail::map<A, K, M, H, P> types;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef std::pair<K const, M> value_type;
|
|
|
|
typedef H hasher;
|
|
|
|
typedef P key_equal;
|
2017-02-23 20:14:27 +00:00
|
|
|
typedef K const const_key_type;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
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;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef boost::unordered::detail::table_impl<types> table;
|
2017-02-23 20:14:27 +00:00
|
|
|
typedef boost::unordered::detail::map_extractor<value_type> extractor;
|
2016-10-22 10:04:36 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef typename boost::unordered::detail::pick_policy<K>::type policy;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef boost::unordered::iterator_detail::iterator<node> iterator;
|
|
|
|
typedef boost::unordered::iterator_detail::c_iterator<node> c_iterator;
|
|
|
|
typedef boost::unordered::iterator_detail::l_iterator<node, policy>
|
|
|
|
l_iterator;
|
|
|
|
typedef boost::unordered::iterator_detail::cl_iterator<node, policy>
|
|
|
|
cl_iterator;
|
|
|
|
};
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
template <typename A, typename K, typename M, typename H, typename P>
|
|
|
|
struct multimap
|
|
|
|
{
|
|
|
|
typedef boost::unordered::detail::multimap<A, K, M, H, P> types;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef std::pair<K const, M> value_type;
|
|
|
|
typedef H hasher;
|
|
|
|
typedef P key_equal;
|
2017-02-23 20:14:27 +00:00
|
|
|
typedef K const const_key_type;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
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;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef boost::unordered::detail::grouped_table_impl<types> table;
|
2017-02-23 20:14:27 +00:00
|
|
|
typedef boost::unordered::detail::map_extractor<value_type> extractor;
|
2016-10-22 10:04:36 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef typename boost::unordered::detail::pick_policy<K>::type policy;
|
2016-08-14 20:55:40 +01:00
|
|
|
|
2017-02-19 13:05:17 +00:00
|
|
|
typedef boost::unordered::iterator_detail::iterator<node> iterator;
|
|
|
|
typedef boost::unordered::iterator_detail::c_iterator<node> c_iterator;
|
|
|
|
typedef boost::unordered::iterator_detail::l_iterator<node, policy>
|
|
|
|
l_iterator;
|
|
|
|
typedef boost::unordered::iterator_detail::cl_iterator<node, policy>
|
|
|
|
cl_iterator;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|