sl@0: // Boost.Range library sl@0: // sl@0: // Copyright Thorsten Ottosen 2003-2004. Use, modification and sl@0: // distribution is subject to the Boost Software License, Version sl@0: // 1.0. (See accompanying file LICENSE_1_0.txt or copy at sl@0: // http://www.boost.org/LICENSE_1_0.txt) sl@0: // sl@0: // For more information, see http://www.boost.org/libs/range/ sl@0: // sl@0: sl@0: #ifndef BOOST_RANGE_DETAIL_BEGIN_HPP sl@0: #define BOOST_RANGE_DETAIL_BEGIN_HPP sl@0: sl@0: #include // BOOST_MSVC sl@0: #include sl@0: #include sl@0: #include sl@0: #if BOOST_WORKAROUND(BOOST_MSVC, < 1310) sl@0: # include sl@0: #endif sl@0: sl@0: namespace boost sl@0: { sl@0: sl@0: namespace range_detail sl@0: { sl@0: template< typename T > sl@0: struct range_begin; sl@0: sl@0: ////////////////////////////////////////////////////////////////////// sl@0: // default sl@0: ////////////////////////////////////////////////////////////////////// sl@0: sl@0: template<> sl@0: struct range_begin sl@0: { sl@0: template< typename C > sl@0: static BOOST_RANGE_DEDUCED_TYPENAME range_result_iterator::type fun( C& c ) sl@0: { sl@0: return c.begin(); sl@0: }; sl@0: }; sl@0: sl@0: ////////////////////////////////////////////////////////////////////// sl@0: // pair sl@0: ////////////////////////////////////////////////////////////////////// sl@0: sl@0: template<> sl@0: struct range_begin sl@0: { sl@0: template< typename P > sl@0: static BOOST_RANGE_DEDUCED_TYPENAME range_result_iterator

::type fun( const P& p ) sl@0: { sl@0: return p.first; sl@0: } sl@0: }; sl@0: sl@0: ////////////////////////////////////////////////////////////////////// sl@0: // array sl@0: ////////////////////////////////////////////////////////////////////// sl@0: sl@0: template<> sl@0: struct range_begin sl@0: { sl@0: #if !BOOST_WORKAROUND(BOOST_MSVC, < 1310) sl@0: template< typename T, std::size_t sz > sl@0: static T* fun( T BOOST_RANGE_ARRAY_REF()[sz] ) sl@0: { sl@0: return boost_range_array; sl@0: } sl@0: #else sl@0: template sl@0: static BOOST_RANGE_DEDUCED_TYPENAME range_value::type* fun(T& t) sl@0: { sl@0: return t; sl@0: } sl@0: #endif sl@0: }; sl@0: sl@0: ////////////////////////////////////////////////////////////////////// sl@0: // string sl@0: ////////////////////////////////////////////////////////////////////// sl@0: sl@0: template<> sl@0: struct range_begin sl@0: { sl@0: static char* fun( char* s ) sl@0: { sl@0: return s; sl@0: } sl@0: }; sl@0: sl@0: template<> sl@0: struct range_begin sl@0: { sl@0: static const char* fun( const char* s ) sl@0: { sl@0: return s; sl@0: } sl@0: }; sl@0: sl@0: template<> sl@0: struct range_begin sl@0: { sl@0: sl@0: static wchar_t* fun( wchar_t* s ) sl@0: { sl@0: return s; sl@0: } sl@0: }; sl@0: sl@0: template<> sl@0: struct range_begin sl@0: { sl@0: static const wchar_t* fun( const wchar_t* s ) sl@0: { sl@0: return s; sl@0: } sl@0: }; sl@0: sl@0: } // namespace 'range_detail' sl@0: sl@0: template< typename C > sl@0: inline BOOST_RANGE_DEDUCED_TYPENAME range_result_iterator::type sl@0: begin( C& c ) sl@0: { sl@0: return range_detail::range_begin< BOOST_RANGE_DEDUCED_TYPENAME range_detail::range::type >::fun( c ); sl@0: } sl@0: sl@0: } // namespace 'boost' sl@0: sl@0: sl@0: #endif