| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 | // Boost.Bimap//// Copyright (c) 2006-2007 Matias Capeletto//// 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)/// \file unordered_set_of.hpp/// \brief Include support for unordered_set constrains for the bimap container#ifndef BOOST_BIMAP_UNORDERED_SET_OF_HPP#define BOOST_BIMAP_UNORDERED_SET_OF_HPP#if defined(_MSC_VER)#pragma once#endif#include <boost/config.hpp>#include <boost/bimap/detail/user_interface_config.hpp>#include <functional>#include <boost/functional/hash.hpp>#include <boost/mpl/bool.hpp>#include <boost/concept_check.hpp>#include <boost/bimap/detail/concept_tags.hpp>#include <boost/bimap/tags/support/value_type_of.hpp>#include <boost/bimap/detail/generate_index_binder.hpp>#include <boost/bimap/detail/generate_view_binder.hpp>#include <boost/bimap/detail/generate_relation_binder.hpp>#include <boost/multi_index/hashed_index.hpp>#include <boost/bimap/views/unordered_map_view.hpp>#include <boost/bimap/views/unordered_set_view.hpp>namespace boost {namespace bimaps {/// \brief Set Type Specification/**This struct is used to specify an unordered_set specification.It is not a container, it is just a metaprogramming facility toexpress the type of a set. Generally, this specification willbe used in other place to create a container.It has the same syntax that an tr1::unordered_set instantiation,except that the allocator cannot be specified. The rationale behindthis difference is that the allocator is not part of theunordered_set type specification, rather it is a containerconfiguration parameter.The first parameter is the type of the objects in the set, thesecond one is a Hash Functor that takes objects of this type, andthe third one is a Functor that compares them for equality.Bimap binding metafunctions can be used with this class inthe following way:\codeusing namespace support;BOOST_STATIC_ASSERT( is_set_type_of< unordered_set_of<Type> >::value )BOOST_STATIC_ASSERT(     is_same     <        unordered_set_of<Type,HashFunctor,EqualKey>::index_bind        <            KeyExtractor,            Tag        >::type,        hashed_unique< tag<Tag>, KeyExtractor, HashFunctor, EqualKey >    >::value)typedef bimap<    unordered_set_of<Type>, RightKeyType> bimap_with_left_type_as_unordered_set;BOOST_STATIC_ASSERT(    is_same    <        unordered_set_of<Type>::map_view_bind        <            member_at::left,            bimap_with_left_type_as_unordered_set        >::type,        unordered_map_view        <            member_at::left,            bimap_with_left_type_as_unordered_set        >    >::value)\endcodeSee also unordered_set_of_relation.                                                                        **/template<    class KeyType,    class HashFunctor   = hash< BOOST_DEDUCED_TYPENAME         ::boost::bimaps::tags::support::value_type_of<KeyType>::type >,    class EqualKey      = std::equal_to< BOOST_DEDUCED_TYPENAME         ::boost::bimaps::tags::support::value_type_of<KeyType>::type >>struct unordered_set_of : public ::boost::bimaps::detail::set_type_of_tag{    /// User type, can be tagged    typedef KeyType user_type;    /// Type of the object that will be stored in the container    typedef BOOST_DEDUCED_TYPENAME ::boost::bimaps::tags::support::        value_type_of<user_type>::type value_type;    /// Hash Functor that takes value_type objects    typedef HashFunctor     hasher;    /// Functor that compare two value_type objects for equality    typedef EqualKey        key_equal;    struct lazy_concept_checked    {        BOOST_CLASS_REQUIRE ( value_type,                              boost, AssignableConcept );        BOOST_CLASS_REQUIRE3( hasher, std::size_t, value_type,                              boost, UnaryFunctionConcept );        BOOST_CLASS_REQUIRE4( key_equal, bool, value_type, value_type,                              boost, BinaryFunctionConcept );        typedef unordered_set_of type;     };    BOOST_BIMAP_GENERATE_INDEX_BINDER_2CP(        // binds to        multi_index::hashed_unique,        // with        hasher,        key_equal    )    BOOST_BIMAP_GENERATE_MAP_VIEW_BINDER(        // binds to        views::unordered_map_view    )    BOOST_BIMAP_GENERATE_SET_VIEW_BINDER(        // binds to        views::unordered_set_view    )    typedef mpl::bool_<false> mutable_key;};/// \brief Set Of Relation Specification/**This struct is similar to unordered_set_of but it is bind logically toa relation. It is used in the bimap instantiation to specify thedesired type of the main view. This struct implements internallya metafunction named bind_to that manages the quite complicatedtask of finding the right type of the set for the relation.\codetemplate<class Relation>struct bind_to{    typedef -unspecified- type;};\endcodeSee also unordered_set_of, is_set_type_of_relation.                                                                **/template<    class HashFunctor   = hash< _relation >,    class EqualKey      = std::equal_to< _relation >>struct unordered_set_of_relation : public ::boost::bimaps::detail::set_type_of_relation_tag{    /// Hash Functor that takes value_type objects    typedef HashFunctor     hasher;    /// Functor that compare two value_type objects for equality    typedef EqualKey        key_equal;    BOOST_BIMAP_GENERATE_RELATION_BINDER_2CP(        // binds to        unordered_set_of,        // with        hasher,        key_equal    )    typedef mpl::bool_<false>  left_mutable_key;    typedef mpl::bool_<false> right_mutable_key;};} // namespace bimaps} // namespace boost#endif // BOOST_BIMAP_UNORDERED_SET_OF_HPP
 |