iterator.hpp
来自「Boost provides free peer-reviewed portab」· HPP 代码 · 共 170 行
HPP
170 行
#ifndef BOOST_MPL_MAP_AUX_ITERATOR_HPP_INCLUDED#define BOOST_MPL_MAP_AUX_ITERATOR_HPP_INCLUDED// Copyright Aleksey Gurtovoy 2003-2004// Copyright David Abrahams 2003-2004//// 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/mpl for documentation.// $Id: iterator.hpp 49267 2008-10-11 06:19:02Z agurtovoy $// $Date: 2008-10-11 02:19:02 -0400 (Sat, 11 Oct 2008) $// $Revision: 49267 $#include <boost/mpl/map/aux_/map0.hpp>#include <boost/mpl/map/aux_/at_impl.hpp>#include <boost/mpl/map/aux_/tag.hpp>#include <boost/mpl/iterator_tags.hpp>#include <boost/mpl/if.hpp>#include <boost/mpl/next.hpp>#include <boost/mpl/deref.hpp>#include <boost/mpl/long.hpp>#include <boost/mpl/void.hpp>#include <boost/mpl/aux_/nttp_decl.hpp>#include <boost/mpl/aux_/config/ctps.hpp>namespace boost { namespace mpl {#if !defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)template< typename Map , long order , long max_order >struct next_order : if_< is_void_< typename item_by_order<Map,order>::type > , next_order<Map,(order+1),max_order> , long_<order> >::type{};template< typename Map , long max_order >struct next_order<Map,max_order,max_order> : long_<max_order>{};template< typename Map, long order, long max_order >struct m_iter{ typedef forward_iterator_tag category; typedef typename item_by_order<Map,order>::type type;};template< typename Map, long max_order >struct m_iter<Map,max_order,max_order>{ typedef forward_iterator_tag category;};template< typename Map, long order, long max_order > struct next< m_iter<Map,order,max_order> >{ typedef m_iter< Map , next_order<Map,order+1,max_order>::value , max_order > type;};template< typename Map, long max_order > struct next< m_iter<Map,max_order,max_order> >{};#elsetemplate< typename Map , BOOST_MPL_AUX_NTTP_DECL(long, order) , BOOST_MPL_AUX_NTTP_DECL(long, max_order) >struct next_order;template< typename Map , BOOST_MPL_AUX_NTTP_DECL(long, order) , BOOST_MPL_AUX_NTTP_DECL(long, max_order) >struct next_order_impl : if_< is_void_< typename item_by_order<Map,order>::type > , next_order<Map,(order+1),max_order> , long_<order> >::type { };template< typename Map , BOOST_MPL_AUX_NTTP_DECL(long, order) , BOOST_MPL_AUX_NTTP_DECL(long, max_order) >struct next_order : if_c< (order != max_order) , next_order_impl<Map,order,max_order> , long_<order> >::type{};template< typename Map , BOOST_MPL_AUX_NTTP_DECL(long, order) , BOOST_MPL_AUX_NTTP_DECL(long, max_order) >struct m_iter;struct m_iter_empty_base {};template< typename Map , BOOST_MPL_AUX_NTTP_DECL(long, order) , BOOST_MPL_AUX_NTTP_DECL(long, max_order) >struct m_iter_base{ typedef typename item_by_order<Map,order>::type type; typedef m_iter< Map , next_order<Map,order+1,max_order>::value , max_order > next;};template< typename Map , BOOST_MPL_AUX_NTTP_DECL(long, order) , BOOST_MPL_AUX_NTTP_DECL(long, max_order) >struct m_iter : if_c< (order == max_order) , m_iter_empty_base , m_iter_base<Map,order,max_order> >::type{ typedef forward_iterator_tag category;};#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION}}#endif // BOOST_MPL_MAP_AUX_ITERATOR_HPP_INCLUDED
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?