unordered_map_view.hpp 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. // Boost.Bimap
  2. //
  3. // Copyright (c) 2006-2007 Matias Capeletto
  4. //
  5. // Distributed under the Boost Software License, Version 1.0.
  6. // (See accompanying file LICENSE_1_0.txt or copy at
  7. // http://www.boost.org/LICENSE_1_0.txt)
  8. /// \file views/unordered_map_view.hpp
  9. /// \brief View of a side of a bimap that is signature compatible with tr1::unordered_map.
  10. #ifndef BOOST_BIMAP_VIEWS_UNOREDERED_MAP_VIEW_HPP
  11. #define BOOST_BIMAP_VIEWS_UNOREDERED_MAP_VIEW_HPP
  12. #if defined(_MSC_VER)
  13. #pragma once
  14. #endif
  15. #include <boost/config.hpp>
  16. #include <utility>
  17. #include <boost/bimap/container_adaptor/unordered_map_adaptor.hpp>
  18. #include <boost/bimap/detail/map_view_base.hpp>
  19. namespace boost {
  20. namespace bimaps {
  21. namespace views {
  22. /// \brief Map View of a bimap, signature compatible with tr1::unordered_map.
  23. /**
  24. This class uses container_adaptor and iterator_adaptor to wrapped a index of the
  25. multi_index bimap core so it can be used as a tr1::unordered_map.
  26. See also const_unordered_map_view.
  27. **/
  28. template< class Tag, class BimapType >
  29. class unordered_map_view
  30. :
  31. public BOOST_BIMAP_MAP_VIEW_CONTAINER_ADAPTOR(
  32. unordered_map_adaptor,
  33. Tag,BimapType,
  34. local_map_view_iterator,const_local_map_view_iterator
  35. ),
  36. public ::boost::bimaps::detail::map_view_base<
  37. unordered_map_view<Tag,BimapType>,Tag,BimapType >,
  38. public ::boost::bimaps::detail::
  39. unique_map_view_access<
  40. unordered_map_view<Tag,BimapType>, Tag, BimapType>::type
  41. {
  42. typedef BOOST_BIMAP_MAP_VIEW_CONTAINER_ADAPTOR(
  43. unordered_map_adaptor,
  44. Tag,BimapType,
  45. local_map_view_iterator,const_local_map_view_iterator
  46. ) base_;
  47. BOOST_BIMAP_MAP_VIEW_BASE_FRIEND(unordered_map_view,Tag,BimapType)
  48. typedef BOOST_DEDUCED_TYPENAME ::boost::bimaps::detail::
  49. unique_map_view_access<
  50. unordered_map_view<Tag,BimapType>, Tag, BimapType
  51. >::type unique_map_view_access_;
  52. public:
  53. typedef std::pair<
  54. BOOST_DEDUCED_TYPENAME base_::iterator,
  55. BOOST_DEDUCED_TYPENAME base_::iterator
  56. > range_type;
  57. typedef std::pair<
  58. BOOST_DEDUCED_TYPENAME base_::const_iterator,
  59. BOOST_DEDUCED_TYPENAME base_::const_iterator
  60. > const_range_type;
  61. typedef BOOST_DEDUCED_TYPENAME base_::value_type::info_type info_type;
  62. unordered_map_view(BOOST_DEDUCED_TYPENAME base_::base_type & c)
  63. : base_(c) {}
  64. using unique_map_view_access_::at;
  65. using unique_map_view_access_::operator[];
  66. unordered_map_view & operator=(const unordered_map_view & v)
  67. {
  68. this->base() = v.base();
  69. return *this;
  70. }
  71. // It can be used enable_if here but the error message when there
  72. // is no info is very clear like this
  73. template< class CompatibleKey >
  74. const info_type & info_at(const CompatibleKey& k) const
  75. {
  76. BOOST_DEDUCED_TYPENAME base_::const_iterator iter = this->find(k);
  77. if( iter == this->end() )
  78. {
  79. ::boost::throw_exception(
  80. std::out_of_range("bimap<>: invalid key")
  81. );
  82. }
  83. return iter->info;
  84. }
  85. template< class CompatibleKey >
  86. info_type & info_at(const CompatibleKey& k)
  87. {
  88. BOOST_DEDUCED_TYPENAME base_::iterator iter = this->find(k);
  89. if( iter == this->end() )
  90. {
  91. ::boost::throw_exception(
  92. std::out_of_range("bimap<>: invalid key")
  93. );
  94. }
  95. return iter->info;
  96. }
  97. };
  98. } // namespace views
  99. /*===========================================================================*/
  100. #define BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF(MAP_VIEW,SIDE,TYPENAME) \
  101. typedef BOOST_DEDUCED_TYPENAME MAP_VIEW::TYPENAME \
  102. BOOST_PP_CAT(SIDE,BOOST_PP_CAT(_,TYPENAME));
  103. /*===========================================================================*/
  104. /*===========================================================================*/
  105. #define BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEFS_BODY(MAP_VIEW,SIDE) \
  106. BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF(MAP_VIEW,SIDE,local_iterator) \
  107. BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF(MAP_VIEW,SIDE,const_local_iterator) \
  108. BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF(MAP_VIEW,SIDE,range_type) \
  109. BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF(MAP_VIEW,SIDE,const_range_type) \
  110. BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF(MAP_VIEW,SIDE,hasher) \
  111. BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF(MAP_VIEW,SIDE,key_equal)
  112. /*===========================================================================*/
  113. namespace detail {
  114. template< class Tag, class BimapType >
  115. struct left_map_view_extra_typedefs< ::boost::bimaps::views::unordered_map_view<Tag,BimapType> >
  116. {
  117. private: typedef ::boost::bimaps::views::unordered_map_view<Tag,BimapType> map_view_;
  118. public : BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEFS_BODY(map_view_,left)
  119. };
  120. template< class Tag, class BimapType >
  121. struct right_map_view_extra_typedefs< ::boost::bimaps::views::unordered_map_view<Tag,BimapType> >
  122. {
  123. private: typedef ::boost::bimaps::views::unordered_map_view<Tag,BimapType> map_view_;
  124. public : BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEFS_BODY(map_view_,right)
  125. };
  126. } // namespace detail
  127. /*===========================================================================*/
  128. #undef BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEF
  129. #undef BOOST_BIMAP_MAP_VIEW_EXTRA_TYPEDEFS_BODY
  130. /*===========================================================================*/
  131. } // namespace bimaps
  132. } // namespace boost
  133. #endif // BOOST_BIMAP_VIEWS_UNOREDERED_MAP_VIEW_HPP