170 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			170 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | 
 | ||
|  | #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$ | ||
|  | // $Date$ | ||
|  | // $Revision$ | ||
|  | 
 | ||
|  | #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> > | ||
|  | { | ||
|  | }; | ||
|  | 
 | ||
|  | #else | ||
|  | 
 | ||
|  | template<  | ||
|  |       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 |