map.hpp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. // Copyright (C) 2005-2016 Daniel James
  2. // Copyright (C) 2022 Christian Mazakas
  3. // Copyright (C) 2024 Braden Ganetsky
  4. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  5. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  6. #include <boost/unordered/detail/implementation.hpp>
  7. #include <boost/unordered/unordered_map_fwd.hpp>
  8. namespace boost {
  9. namespace unordered {
  10. namespace detail {
  11. template <typename A, typename K, typename M, typename H, typename P>
  12. struct map
  13. {
  14. typedef boost::unordered::detail::map<A, K, M, H, P> types;
  15. typedef std::pair<K const, M> value_type;
  16. typedef H hasher;
  17. typedef P key_equal;
  18. typedef K key_type;
  19. typedef K const const_key_type;
  20. typedef
  21. typename ::boost::unordered::detail::rebind_wrap<A, value_type>::type
  22. value_allocator;
  23. typedef boost::unordered::detail::allocator_traits<value_allocator>
  24. value_allocator_traits;
  25. typedef boost::unordered::detail::table<types> table;
  26. typedef boost::unordered::detail::map_extractor<value_type> extractor;
  27. typedef typename boost::allocator_void_pointer<value_allocator>::type
  28. void_pointer;
  29. typedef boost::unordered::node_handle_map<
  30. node<value_type, void_pointer>, K, M, A>
  31. node_type;
  32. typedef typename table::iterator iterator;
  33. typedef boost::unordered::insert_return_type_map<iterator, node_type> insert_return_type;
  34. };
  35. }
  36. }
  37. }