274 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			274 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| //  Boost string_algo library find_format_all.hpp header file  ---------------------------//
 | |
| 
 | |
| //  Copyright Pavol Droba 2002-2003.
 | |
| //
 | |
| // 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/ for updates, documentation, and revision history.
 | |
| 
 | |
| #ifndef BOOST_STRING_FIND_FORMAT_ALL_DETAIL_HPP
 | |
| #define BOOST_STRING_FIND_FORMAT_ALL_DETAIL_HPP
 | |
| 
 | |
| #include <boost/algorithm/string/config.hpp>
 | |
| #include <boost/range/iterator_range_core.hpp>
 | |
| #include <boost/range/const_iterator.hpp>
 | |
| #include <boost/range/value_type.hpp>
 | |
| #include <boost/algorithm/string/detail/find_format_store.hpp>
 | |
| #include <boost/algorithm/string/detail/replace_storage.hpp>
 | |
| 
 | |
| namespace boost {
 | |
|     namespace algorithm {
 | |
|         namespace detail {
 | |
| 
 | |
| // find_format_all_copy (iterator variant) implementation ---------------------------//
 | |
| 
 | |
|            template< 
 | |
|                 typename OutputIteratorT,
 | |
|                 typename InputT,
 | |
|                 typename FinderT,
 | |
|                 typename FormatterT,
 | |
|                 typename FindResultT,
 | |
|                 typename FormatResultT >
 | |
|             inline OutputIteratorT find_format_all_copy_impl2(
 | |
|                 OutputIteratorT Output,
 | |
|                 const InputT& Input,
 | |
|                 FinderT Finder,
 | |
|                 FormatterT Formatter,
 | |
|                 const FindResultT& FindResult,
 | |
|                 const FormatResultT& FormatResult )
 | |
|             {       
 | |
|                 typedef BOOST_STRING_TYPENAME 
 | |
|                     range_const_iterator<InputT>::type input_iterator_type; 
 | |
| 
 | |
|                 typedef find_format_store<
 | |
|                         input_iterator_type, 
 | |
|                         FormatterT,
 | |
|                         FormatResultT > store_type;
 | |
| 
 | |
|                 // Create store for the find result
 | |
|                 store_type M( FindResult, FormatResult, Formatter );
 | |
| 
 | |
|                 // Initialize last match
 | |
|                 input_iterator_type LastMatch=::boost::begin(Input);
 | |
| 
 | |
|                 // Iterate through all matches
 | |
|                 while( M )
 | |
|                 {
 | |
|                     // Copy the beginning of the sequence
 | |
|                     Output = std::copy( LastMatch, M.begin(), Output );
 | |
|                     // Copy formatted result
 | |
|                     Output = std::copy( ::boost::begin(M.format_result()), ::boost::end(M.format_result()), Output );
 | |
| 
 | |
|                     // Proceed to the next match
 | |
|                     LastMatch=M.end();
 | |
|                     M=Finder( LastMatch, ::boost::end(Input) );
 | |
|                 }
 | |
| 
 | |
|                 // Copy the rest of the sequence
 | |
|                 Output = std::copy( LastMatch, ::boost::end(Input), Output );
 | |
| 
 | |
|                 return Output;
 | |
|             }
 | |
| 
 | |
|             template< 
 | |
|                 typename OutputIteratorT,
 | |
|                 typename InputT,
 | |
|                 typename FinderT,
 | |
|                 typename FormatterT,
 | |
|                 typename FindResultT >
 | |
|             inline OutputIteratorT find_format_all_copy_impl(
 | |
|                 OutputIteratorT Output,
 | |
|                 const InputT& Input,
 | |
|                 FinderT Finder,
 | |
|                 FormatterT Formatter,
 | |
|                 const FindResultT& FindResult )
 | |
|             {   
 | |
|                 if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) {
 | |
|                     return ::boost::algorithm::detail::find_format_all_copy_impl2( 
 | |
|                         Output,
 | |
|                         Input,
 | |
|                         Finder,
 | |
|                         Formatter,
 | |
|                         FindResult,
 | |
|                         Formatter(FindResult) );
 | |
|                 } else {
 | |
|                     return std::copy( ::boost::begin(Input), ::boost::end(Input), Output );
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|  // find_format_all_copy implementation ----------------------------------------------//
 | |
| 
 | |
|            template< 
 | |
|                 typename InputT, 
 | |
|                 typename FinderT,
 | |
|                 typename FormatterT,
 | |
|                 typename FindResultT,
 | |
|                 typename FormatResultT >
 | |
|             inline InputT find_format_all_copy_impl2(
 | |
|                 const InputT& Input,
 | |
|                 FinderT Finder,
 | |
|                 FormatterT Formatter,
 | |
|                 const FindResultT& FindResult,
 | |
|                 const FormatResultT& FormatResult)
 | |
|             {
 | |
|                 typedef BOOST_STRING_TYPENAME 
 | |
|                     range_const_iterator<InputT>::type input_iterator_type; 
 | |
| 
 | |
|                 typedef find_format_store<
 | |
|                         input_iterator_type, 
 | |
|                         FormatterT,
 | |
|                         FormatResultT > store_type;
 | |
| 
 | |
|                 // Create store for the find result
 | |
|                 store_type M( FindResult, FormatResult, Formatter );
 | |
| 
 | |
|                 // Initialize last match
 | |
|                 input_iterator_type LastMatch=::boost::begin(Input);
 | |
| 
 | |
|                 // Output temporary
 | |
|                 InputT Output;
 | |
| 
 | |
|                 // Iterate through all matches
 | |
|                 while( M )
 | |
|                 {
 | |
|                     // Copy the beginning of the sequence
 | |
|                     boost::algorithm::detail::insert( Output, ::boost::end(Output), LastMatch, M.begin() );
 | |
|                     // Copy formatted result
 | |
|                     boost::algorithm::detail::insert( Output, ::boost::end(Output), M.format_result() );
 | |
| 
 | |
|                     // Proceed to the next match
 | |
|                     LastMatch=M.end();
 | |
|                     M=Finder( LastMatch, ::boost::end(Input) );
 | |
|                 }
 | |
| 
 | |
|                 // Copy the rest of the sequence
 | |
|                 ::boost::algorithm::detail::insert( Output, ::boost::end(Output), LastMatch, ::boost::end(Input) );
 | |
| 
 | |
|                 return Output;
 | |
|             }
 | |
| 
 | |
|             template< 
 | |
|                 typename InputT, 
 | |
|                 typename FinderT,
 | |
|                 typename FormatterT,
 | |
|                 typename FindResultT >
 | |
|             inline InputT find_format_all_copy_impl(
 | |
|                 const InputT& Input,
 | |
|                 FinderT Finder,
 | |
|                 FormatterT Formatter,
 | |
|                 const FindResultT& FindResult)
 | |
|             {
 | |
|                 if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) {
 | |
|                     return ::boost::algorithm::detail::find_format_all_copy_impl2(
 | |
|                         Input,
 | |
|                         Finder,
 | |
|                         Formatter,
 | |
|                         FindResult,
 | |
|                         Formatter(FindResult) );
 | |
|                 } else {
 | |
|                     return Input;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|  // find_format_all implementation ------------------------------------------------//
 | |
|         
 | |
|             template<
 | |
|                 typename InputT,
 | |
|                 typename FinderT,
 | |
|                 typename FormatterT,
 | |
|                 typename FindResultT,
 | |
|                 typename FormatResultT >
 | |
|             inline void find_format_all_impl2( 
 | |
|                 InputT& Input,
 | |
|                 FinderT Finder,
 | |
|                 FormatterT Formatter,
 | |
|                 FindResultT FindResult,
 | |
|                 FormatResultT FormatResult)
 | |
|             {
 | |
|                 typedef BOOST_STRING_TYPENAME 
 | |
|                     range_iterator<InputT>::type input_iterator_type; 
 | |
|                 typedef find_format_store<
 | |
|                         input_iterator_type, 
 | |
|                         FormatterT,
 | |
|                         FormatResultT > store_type;
 | |
| 
 | |
|                 // Create store for the find result
 | |
|                 store_type M( FindResult, FormatResult, Formatter );
 | |
|           
 | |
|                 // Instantiate replacement storage
 | |
|                 std::deque<
 | |
|                     BOOST_STRING_TYPENAME range_value<InputT>::type> Storage;
 | |
| 
 | |
|                 // Initialize replacement iterators
 | |
|                 input_iterator_type InsertIt=::boost::begin(Input);
 | |
|                 input_iterator_type SearchIt=::boost::begin(Input);
 | |
|                 
 | |
|                 while( M )
 | |
|                 {
 | |
|                     // process the segment
 | |
|                     InsertIt=process_segment( 
 | |
|                         Storage,
 | |
|                         Input,
 | |
|                         InsertIt,
 | |
|                         SearchIt,
 | |
|                         M.begin() );
 | |
|                     
 | |
|                     // Adjust search iterator
 | |
|                     SearchIt=M.end();
 | |
| 
 | |
|                     // Copy formatted replace to the storage
 | |
|                     ::boost::algorithm::detail::copy_to_storage( Storage, M.format_result() );
 | |
| 
 | |
|                     // Find range for a next match
 | |
|                     M=Finder( SearchIt, ::boost::end(Input) );
 | |
|                 }
 | |
| 
 | |
|                 // process the last segment
 | |
|                 InsertIt=::boost::algorithm::detail::process_segment( 
 | |
|                     Storage,
 | |
|                     Input,
 | |
|                     InsertIt,
 | |
|                     SearchIt,
 | |
|                     ::boost::end(Input) );
 | |
|                 
 | |
|                 if ( Storage.empty() )
 | |
|                 {
 | |
|                     // Truncate input
 | |
|                     ::boost::algorithm::detail::erase( Input, InsertIt, ::boost::end(Input) );
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     // Copy remaining data to the end of input
 | |
|                     ::boost::algorithm::detail::insert( Input, ::boost::end(Input), Storage.begin(), Storage.end() );
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             template<
 | |
|                 typename InputT,
 | |
|                 typename FinderT,
 | |
|                 typename FormatterT,
 | |
|                 typename FindResultT >
 | |
|             inline void find_format_all_impl( 
 | |
|                 InputT& Input,
 | |
|                 FinderT Finder,
 | |
|                 FormatterT Formatter,
 | |
|                 FindResultT FindResult)
 | |
|             {
 | |
|                 if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) {
 | |
|                     ::boost::algorithm::detail::find_format_all_impl2(
 | |
|                         Input,
 | |
|                         Finder,
 | |
|                         Formatter,
 | |
|                         FindResult,
 | |
|                         Formatter(FindResult) );
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|         } // namespace detail
 | |
|     } // namespace algorithm
 | |
| } // namespace boost
 | |
| 
 | |
| #endif  // BOOST_STRING_FIND_FORMAT_ALL_DETAIL_HPP
 | 
