forked from boostorg/algorithm
		
	
		
			
				
	
	
		
			105 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //  Boost string_algo library util.hpp header file  ---------------------------//
 | |
| 
 | |
| //  Copyright Pavol Droba 2002-2003. 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)
 | |
| 
 | |
| //  See http://www.boost.org for updates, documentation, and revision history.
 | |
| 
 | |
| #ifndef BOOST_STRING_UTIL_DETAIL_HPP
 | |
| #define BOOST_STRING_UTIL_DETAIL_HPP
 | |
| 
 | |
| #include <boost/algorithm/string/config.hpp>
 | |
| #include <functional>
 | |
| 
 | |
| namespace boost {
 | |
|     namespace algorithm {
 | |
|         namespace detail {
 | |
| 
 | |
| //  empty container  -----------------------------------------------//
 | |
| 
 | |
|             //  empty_container 
 | |
|             /*
 | |
|                 This class represents always empty container,
 | |
|                 containing elemets of type CharT.
 | |
| 
 | |
|                 It is supposed to be used in a const version only
 | |
|             */
 | |
|             template< typename CharT >
 | |
|             struct empty_container 
 | |
|             {
 | |
|                 typedef empty_container<CharT> type;        
 | |
|                 typedef CharT value_type;
 | |
|                 typedef std::size_t size_type;
 | |
|                 typedef std::ptrdiff_t difference_type;
 | |
|                 typedef const value_type& reference;
 | |
|                 typedef const value_type& const_reference;
 | |
|                 typedef const value_type* iterator;
 | |
|                 typedef const value_type* const_iterator;
 | |
| 
 | |
|                 
 | |
|                 // Operations
 | |
|                 const_iterator begin() const
 | |
|                 {
 | |
|                     return reinterpret_cast<const_iterator>(0);
 | |
|                 }
 | |
| 
 | |
|                 const_iterator end() const
 | |
|                 {
 | |
|                     return reinterpret_cast<const_iterator>(0);
 | |
|                 }
 | |
| 
 | |
|                 bool empty() const
 | |
|                 {
 | |
|                     return false;
 | |
|                 }
 | |
| 
 | |
|                 size_type size() const
 | |
|                 {
 | |
|                     return 0;
 | |
|                 }
 | |
|             };
 | |
|     
 | |
| //  bounded copy algorithm  -----------------------------------------------//
 | |
| 
 | |
|             // Bounded version of the std::copy algorithm
 | |
|             template<typename InputIteratorT, typename OutputIteratorT>
 | |
|             inline OutputIteratorT bounded_copy(
 | |
|                 InputIteratorT First, 
 | |
|                 InputIteratorT Last, 
 | |
|                 OutputIteratorT DestFirst,
 | |
|                 OutputIteratorT DestLast )
 | |
|             {
 | |
|                 InputIteratorT InputIt=First;
 | |
|                 OutputIteratorT OutputIt=DestFirst;
 | |
|                 for(; InputIt!=Last && OutputIt!=DestLast; InputIt++, OutputIt++ )
 | |
|                 {
 | |
|                     *OutputIt=*InputIt;
 | |
|                 }
 | |
| 
 | |
|                 return OutputIt;
 | |
|             }
 | |
| 
 | |
| //  iterator range utilities -----------------------------------------//
 | |
| 
 | |
|             // copy range functor
 | |
|             template< 
 | |
|                 typename SeqT, 
 | |
|                 typename IteratorT=BOOST_STRING_TYPENAME SeqT::const_iterator >
 | |
|             struct copy_iterator_rangeF : 
 | |
|                 public std::unary_function< iterator_range<IteratorT>, SeqT >
 | |
|             {
 | |
|                 SeqT operator()( const iterator_range<IteratorT>& Range ) const
 | |
|                 {
 | |
|                     return copy_iterator_range<SeqT>(Range);
 | |
|                 }
 | |
|             };
 | |
| 
 | |
|         } // namespace detail
 | |
|     } // namespace algorithm
 | |
| } // namespace boost
 | |
| 
 | |
| 
 | |
| #endif  // BOOST_STRING_UTIL_DETAIL_HPP
 |