⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 iterator.hpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 HPP
字号:
#ifndef BOOST_MPL_AUX_RANGE_C_ITERATOR_HPP_INCLUDED#define BOOST_MPL_AUX_RANGE_C_ITERATOR_HPP_INCLUDED// Copyright Aleksey Gurtovoy 2000-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/iterator_tags.hpp>#include <boost/mpl/advance_fwd.hpp>#include <boost/mpl/distance_fwd.hpp>#include <boost/mpl/next_prior.hpp>#include <boost/mpl/deref.hpp>#include <boost/mpl/plus.hpp>#include <boost/mpl/minus.hpp>#include <boost/mpl/aux_/value_wknd.hpp>#include <boost/mpl/aux_/config/ctps.hpp>namespace boost { namespace mpl {// theoretically will work on any discrete numeric typetemplate< typename N > struct r_iter{    typedef aux::r_iter_tag tag;    typedef random_access_iterator_tag category;    typedef N type;#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)    typedef r_iter< typename mpl::next<N>::type > next;    typedef r_iter< typename mpl::prior<N>::type > prior;#endif};#if !defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)template<      typename N    >struct next< r_iter<N> >{    typedef r_iter< typename mpl::next<N>::type > type;};template<      typename N    >struct prior< r_iter<N> >{    typedef r_iter< typename mpl::prior<N>::type > type;};#endiftemplate<> struct advance_impl<aux::r_iter_tag>{    template< typename Iter, typename Dist > struct apply    {        typedef typename deref<Iter>::type n_;#if BOOST_WORKAROUND(BOOST_MSVC, <= 1300)        typedef typename plus_impl<integral_c_tag,integral_c_tag>            ::template apply<n_,Dist>::type m_;#else        typedef typename plus<n_,Dist>::type m_;#endif        // agurt, 10/nov/04: to be generic, the code have to do something along        // the lines below...        //        // typedef typename apply_wrap1<        //       numeric_cast< typename m_::tag, typename n_::tag >        //     , m_        //     >::type result_;        //        // ... meanwhile:                typedef integral_c<               typename aux::value_type_wknd<n_>::type            , BOOST_MPL_AUX_VALUE_WKND(m_)::value             > result_;                typedef r_iter<result_> type;    };};template<> struct distance_impl<aux::r_iter_tag>{    template< typename Iter1, typename Iter2 > struct apply        : minus<              typename Iter2::type            , typename Iter1::type            >    {    };};}}#endif // BOOST_MPL_AUX_RANGE_C_ITERATOR_HPP_INCLUDED

⌨️ 快捷键说明

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