126 lines
4.1 KiB
C++
126 lines
4.1 KiB
C++
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
//
|
||
|
// (C) Copyright Ion Gaztanaga 2005-2012. 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)
|
||
|
//
|
||
|
// See http://www.boost.org/libs/interprocess for documentation.
|
||
|
//
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
#ifndef BOOST_INTERPROCESS_UNORDERED_MAP_INDEX_HPP
|
||
|
#define BOOST_INTERPROCESS_UNORDERED_MAP_INDEX_HPP
|
||
|
|
||
|
#ifndef BOOST_CONFIG_HPP
|
||
|
# include <boost/config.hpp>
|
||
|
#endif
|
||
|
#
|
||
|
#if defined(BOOST_HAS_PRAGMA_ONCE)
|
||
|
# pragma once
|
||
|
#endif
|
||
|
|
||
|
#include <boost/interprocess/detail/config_begin.hpp>
|
||
|
#include <boost/interprocess/detail/workaround.hpp>
|
||
|
|
||
|
#include <boost/intrusive/detail/minimal_pair_header.hpp>
|
||
|
#include <boost/unordered_map.hpp>
|
||
|
#include <boost/interprocess/detail/utilities.hpp>
|
||
|
#include <boost/interprocess/allocators/private_adaptive_pool.hpp>
|
||
|
|
||
|
#include <boost/intrusive/detail/minimal_pair_header.hpp> //std::pair
|
||
|
#include <boost/intrusive/detail/minimal_less_equal_header.hpp> //std::less
|
||
|
|
||
|
//!\file
|
||
|
//!Describes index adaptor of boost::unordered_map container, to use it
|
||
|
//!as name/shared memory index
|
||
|
|
||
|
namespace boost {
|
||
|
namespace interprocess {
|
||
|
|
||
|
#if !defined(BOOST_INTERPROCESS_DOXYGEN_INVOKED)
|
||
|
|
||
|
//!Helper class to define typedefs from
|
||
|
//!IndexTraits
|
||
|
template <class MapConfig>
|
||
|
struct unordered_map_index_aux
|
||
|
{
|
||
|
typedef typename MapConfig::key_type key_type;
|
||
|
typedef typename MapConfig::mapped_type mapped_type;
|
||
|
typedef std::equal_to<key_type> key_equal;
|
||
|
typedef std::pair<const key_type, mapped_type> value_type;
|
||
|
typedef private_adaptive_pool
|
||
|
<value_type,
|
||
|
typename MapConfig::
|
||
|
segment_manager_base> allocator_type;
|
||
|
struct hasher
|
||
|
{
|
||
|
typedef key_type argument_type;
|
||
|
typedef std::size_t result_type;
|
||
|
|
||
|
std::size_t operator()(const key_type &val) const
|
||
|
{
|
||
|
typedef typename key_type::char_type char_type;
|
||
|
const char_type *beg = ipcdetail::to_raw_pointer(val.mp_str),
|
||
|
*end = beg + val.m_len;
|
||
|
return boost::hash_range(beg, end);
|
||
|
}
|
||
|
};
|
||
|
typedef unordered_map<key_type, mapped_type, hasher,
|
||
|
key_equal, allocator_type> index_t;
|
||
|
};
|
||
|
|
||
|
#endif //#ifndef BOOST_INTERPROCESS_DOXYGEN_INVOKED
|
||
|
|
||
|
//!Index type based in unordered_map. Just derives from unordered_map and
|
||
|
//!defines the interface needed by managed memory segments
|
||
|
template <class MapConfig>
|
||
|
class unordered_map_index
|
||
|
//Derive class from unordered_map specialization
|
||
|
: public unordered_map_index_aux<MapConfig>::index_t
|
||
|
{
|
||
|
#if !defined(BOOST_INTERPROCESS_DOXYGEN_INVOKED)
|
||
|
typedef unordered_map_index_aux<MapConfig> index_aux;
|
||
|
typedef typename index_aux::index_t base_type;
|
||
|
typedef typename
|
||
|
MapConfig::segment_manager_base segment_manager_base;
|
||
|
#endif //#ifndef BOOST_INTERPROCESS_DOXYGEN_INVOKED
|
||
|
|
||
|
public:
|
||
|
//!Constructor. Takes a pointer to the
|
||
|
//!segment manager. Can throw
|
||
|
unordered_map_index(segment_manager_base *segment_mngr)
|
||
|
: base_type(0,
|
||
|
typename index_aux::hasher(),
|
||
|
typename index_aux::key_equal(),
|
||
|
segment_mngr){}
|
||
|
|
||
|
//!This reserves memory to optimize the insertion of n
|
||
|
//!elements in the index
|
||
|
void reserve(typename segment_manager_base::size_type n)
|
||
|
{ base_type::rehash(n); }
|
||
|
|
||
|
//!This tries to free previously allocate
|
||
|
//!unused memory.
|
||
|
void shrink_to_fit()
|
||
|
{ base_type::rehash(base_type::size()); }
|
||
|
};
|
||
|
|
||
|
#if !defined(BOOST_INTERPROCESS_DOXYGEN_INVOKED)
|
||
|
|
||
|
//!Trait class to detect if an index is a node
|
||
|
//!index. This allows more efficient operations
|
||
|
//!when deallocating named objects.
|
||
|
template<class MapConfig>
|
||
|
struct is_node_index
|
||
|
<boost::interprocess::unordered_map_index<MapConfig> >
|
||
|
{
|
||
|
static const bool value = true;
|
||
|
};
|
||
|
#endif //#ifndef BOOST_INTERPROCESS_DOXYGEN_INVOKED
|
||
|
|
||
|
}} //namespace boost { namespace interprocess {
|
||
|
|
||
|
#include <boost/interprocess/detail/config_end.hpp>
|
||
|
|
||
|
#endif //#ifndef BOOST_INTERPROCESS_UNORDERED_MAP_INDEX_HPP
|