// Boost.Range library // // Copyright Thorsten Ottosen 2006. Use, modification and // distribution is subject to 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) // // For more information, see http://www.boost.org/libs/range/ // #ifndef BOOST_RANGE_DETAIL_AS_LITERAL_HPP #define BOOST_RANGE_DETAIL_AS_LITERAL_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif #ifdef BOOST_NO_FUNCTION_TEMPLATE_ORDERING #include #else #include #include #include #include #include namespace boost { namespace range_detail { inline std::size_t length( const char* s ) { return strlen( s ); } inline std::size_t length( const wchar_t* s ) { return wcslen( s ); } // // Remark: the compiler cannot choose between T* and T[sz] // overloads, so we must put the T* internal to the // unconstrained version. // inline bool is_char_ptr( char* ) { return true; } inline bool is_char_ptr( const char* ) { return true; } inline bool is_char_ptr( wchar_t* ) { return true; } inline bool is_char_ptr( const wchar_t* ) { return true; } template< class T > inline long is_char_ptr( T /* r */ ) { return 0L; } template< class T > inline iterator_range make_range( T* const r, bool ) { return iterator_range( r, r + length(r) ); } template< class T > inline iterator_range::type> make_range( T& r, long ) { return boost::make_iterator_range( r ); } } template< class Range > inline iterator_range::type> as_literal( Range& r ) { return range_detail::make_range( r, range_detail::is_char_ptr(r) ); } template< class Range > inline iterator_range::type> as_literal( const Range& r ) { return range_detail::make_range( r, range_detail::is_char_ptr(r) ); } template< class Char, std::size_t sz > inline iterator_range as_literal( Char (&arr)[sz] ) { #if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x590)) && __BORLANDC__ >= 0x590 return boost::make_iterator_range( arr, arr + sz - 1 ); #else return boost::make_iterator_range( arr, arr + sz - 1 ); #endif } template< class Char, std::size_t sz > inline iterator_range as_literal( const Char (&arr)[sz] ) { #if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x590)) && __BORLANDC__ >= 0x590 return boost::make_iterator_range( arr, arr + sz - 1 ); #else return boost::make_iterator_range( arr, arr + sz - 1 ); #endif } } #endif // BOOST_NO_FUNCTION_TEMPLATE_ORDERING #endif