hash_index_node.hpp

来自「Boost provides free peer-reviewed portab」· HPP 代码 · 共 166 行

HPP
166
字号
/* Copyright 2003-2008 Joaquin M Lopez Munoz. * 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/multi_index for library home page. */#ifndef BOOST_MULTI_INDEX_DETAIL_HASH_INDEX_NODE_HPP#define BOOST_MULTI_INDEX_DETAIL_HASH_INDEX_NODE_HPP#if defined(_MSC_VER)&&(_MSC_VER>=1200)#pragma once#endif#include <boost/config.hpp> /* keep it first to prevent nasty warns in MSVC */#include <boost/detail/allocator_utilities.hpp>#include <boost/multi_index/detail/prevent_eti.hpp>#include <functional>namespace boost{namespace multi_index{namespace detail{/* singly-linked node for use by hashed_index */template<typename Allocator>struct hashed_index_node_impl{  typedef typename prevent_eti<    Allocator,    typename boost::detail::allocator::rebind_to<      Allocator,hashed_index_node_impl    >::type  >::type::pointer                                pointer;  typedef typename prevent_eti<    Allocator,    typename boost::detail::allocator::rebind_to<      Allocator,hashed_index_node_impl    >::type  >::type::const_pointer                          const_pointer;  pointer& next(){return next_;}  pointer  next()const{return next_;}  /* algorithmic stuff */  static void increment(pointer& x,pointer bbegin,pointer bend)  {    std::less_equal<pointer> leq;    x=x->next();    if(leq(bbegin,x)&&leq(x,bend)){ /* bucket node */      do{        ++x;      }while(x->next()==x);      x=x->next();    }  }  static void link(pointer x,pointer pos)  {    x->next()=pos->next();    pos->next()=x;  };  static void unlink(pointer x)  {    pointer y=x->next();    while(y->next()!=x){y=y->next();}    y->next()=x->next();  }  static pointer prev(pointer x)  {    pointer y=x->next();    while(y->next()!=x){y=y->next();}    return y;  }  static void unlink_next(pointer x)  {    x->next()=x->next()->next();  }private:  pointer next_;};template<typename Super>struct hashed_index_node_trampoline:  prevent_eti<    Super,    hashed_index_node_impl<      typename boost::detail::allocator::rebind_to<        typename Super::allocator_type,        char      >::type    >  >::type{  typedef typename prevent_eti<    Super,    hashed_index_node_impl<      typename boost::detail::allocator::rebind_to<        typename Super::allocator_type,        char      >::type    >  >::type impl_type;};template<typename Super>struct hashed_index_node:Super,hashed_index_node_trampoline<Super>{private:  typedef hashed_index_node_trampoline<Super> trampoline;public:  typedef typename trampoline::impl_type     impl_type;  typedef typename trampoline::pointer       impl_pointer;  typedef typename trampoline::const_pointer const_impl_pointer;  impl_pointer impl()  {    return static_cast<impl_pointer>(      static_cast<impl_type*>(static_cast<trampoline*>(this)));  }  const_impl_pointer impl()const  {    return static_cast<const_impl_pointer>(      static_cast<const impl_type*>(static_cast<const trampoline*>(this)));  }  static hashed_index_node* from_impl(impl_pointer x)  {    return static_cast<hashed_index_node*>(      static_cast<trampoline*>(&*x));  }  static const hashed_index_node* from_impl(const_impl_pointer x)  {    return static_cast<const hashed_index_node*>(      static_cast<const trampoline*>(&*x));  }  static void increment(    hashed_index_node*& x,impl_pointer bbegin,impl_pointer bend)  {    impl_pointer xi=x->impl();    trampoline::increment(xi,bbegin,bend);    x=from_impl(xi);  }};} /* namespace multi_index::detail */} /* namespace multi_index */} /* namespace boost */#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?