| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | //  Boost string_algo library iter_find.hpp header file  ---------------------------//
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-27 10:27:37 +00:00
										 |  |  | //  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)
 | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-27 10:27:37 +00:00
										 |  |  | //  See http://www.boost.org/ for updates, documentation, and revision history.
 | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef BOOST_STRING_ITER_FIND_HPP
 | 
					
						
							|  |  |  | #define BOOST_STRING_ITER_FIND_HPP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/algorithm/string/config.hpp>
 | 
					
						
							|  |  |  | #include <algorithm>
 | 
					
						
							|  |  |  | #include <iterator>
 | 
					
						
							|  |  |  | #include <boost/iterator/transform_iterator.hpp>
 | 
					
						
							| 
									
										
										
										
											2005-01-21 16:45:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <boost/range/iterator_range.hpp>
 | 
					
						
							|  |  |  | #include <boost/range/begin.hpp>
 | 
					
						
							|  |  |  | #include <boost/range/end.hpp>
 | 
					
						
							| 
									
										
										
										
											2007-10-27 22:52:29 +00:00
										 |  |  | #include <boost/range/iterator.hpp>
 | 
					
						
							| 
									
										
										
										
											2005-01-21 16:45:29 +00:00
										 |  |  | #include <boost/range/value_type.hpp>
 | 
					
						
							| 
									
										
										
										
											2007-07-01 22:23:55 +00:00
										 |  |  | #include <boost/range/as_literal.hpp>
 | 
					
						
							| 
									
										
										
										
											2005-01-21 16:45:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | #include <boost/algorithm/string/concept.hpp>
 | 
					
						
							|  |  |  | #include <boost/algorithm/string/find_iterator.hpp>
 | 
					
						
							|  |  |  | #include <boost/algorithm/string/detail/util.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! \file
 | 
					
						
							|  |  |  |     Defines generic split algorithms. Split algorithms can be  | 
					
						
							|  |  |  |     used to divide a sequence into several part according  | 
					
						
							| 
									
										
										
										
											2004-07-14 22:24:12 +00:00
										 |  |  |     to a given criteria. Result is given as a 'container  | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |     of containers' where elements are copies or references  | 
					
						
							|  |  |  |     to extracted parts. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     There are two algorithms provided. One iterates over matching | 
					
						
							| 
									
										
										
										
											2004-07-15 21:48:25 +00:00
										 |  |  |     substrings, the other one over the gaps between these matches. | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace boost { | 
					
						
							|  |  |  |     namespace algorithm { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //  iterate find ---------------------------------------------------//
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //! Iter find algorithm
 | 
					
						
							|  |  |  |         /*!
 | 
					
						
							|  |  |  |             This algorithm executes a given finder in iteration on the input, | 
					
						
							|  |  |  |             until the end of input is reached, or no match is found. | 
					
						
							|  |  |  |             Iteration is done using built-in find_iterator, so the real  | 
					
						
							|  |  |  |             searching is performed only when needed. | 
					
						
							|  |  |  |             In each iteration new match is found and added to the result. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             \param Result A 'container container' to contain the result of search. | 
					
						
							|  |  |  |                 Both outer and inner container must have constructor taking a pair | 
					
						
							|  |  |  |                 of iterators as an argument. | 
					
						
							|  |  |  |                 Typical type of the result is  | 
					
						
							|  |  |  |                     \c std::vector<boost::iterator_range<iterator>> | 
					
						
							|  |  |  |                 (each element of such a vector will container a range delimiting  | 
					
						
							|  |  |  |                 a match). | 
					
						
							|  |  |  |             \param Input A container which will be searched. | 
					
						
							|  |  |  |             \param Finder A Finder object used for searching | 
					
						
							| 
									
										
										
										
											2012-07-05 15:14:40 +00:00
										 |  |  |             \return A reference to the result | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-15 21:48:25 +00:00
										 |  |  |             \note Prior content of the result will be overwritten. | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |         */ | 
					
						
							|  |  |  |         template<  | 
					
						
							|  |  |  |             typename SequenceSequenceT, | 
					
						
							| 
									
										
										
										
											2005-04-12 16:50:42 +00:00
										 |  |  |             typename RangeT, | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             typename FinderT > | 
					
						
							|  |  |  |         inline SequenceSequenceT& | 
					
						
							|  |  |  |         iter_find( | 
					
						
							|  |  |  |             SequenceSequenceT& Result, | 
					
						
							| 
									
										
										
										
											2005-04-12 16:50:42 +00:00
										 |  |  |             RangeT& Input, | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             FinderT Finder ) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |             BOOST_CONCEPT_ASSERT(( | 
					
						
							|  |  |  |                 FinderConcept< | 
					
						
							|  |  |  |                     FinderT, | 
					
						
							|  |  |  |                     BOOST_STRING_TYPENAME range_iterator<RangeT>::type> | 
					
						
							|  |  |  |                 )); | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |             iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); | 
					
						
							| 
									
										
										
										
											2007-07-01 22:23:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             typedef BOOST_STRING_TYPENAME  | 
					
						
							| 
									
										
										
										
											2007-10-27 22:52:29 +00:00
										 |  |  |                 range_iterator<RangeT>::type input_iterator_type; | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             typedef find_iterator<input_iterator_type> find_iterator_type; | 
					
						
							|  |  |  |             typedef detail::copy_iterator_rangeF< | 
					
						
							|  |  |  |                 BOOST_STRING_TYPENAME  | 
					
						
							| 
									
										
										
										
											2005-01-21 16:45:29 +00:00
										 |  |  |                     range_value<SequenceSequenceT>::type, | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |                 input_iterator_type> copy_range_type; | 
					
						
							|  |  |  |              | 
					
						
							| 
									
										
										
										
											2008-06-17 21:04:00 +00:00
										 |  |  |             input_iterator_type InputEnd=::boost::end(lit_input); | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |             typedef transform_iterator<copy_range_type, find_iterator_type> | 
					
						
							|  |  |  |                 transform_iter_type; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |             transform_iter_type itBegin= | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |                 ::boost::make_transform_iterator(  | 
					
						
							| 
									
										
										
										
											2008-06-17 21:04:00 +00:00
										 |  |  |                     find_iterator_type( ::boost::begin(lit_input), InputEnd, Finder ), | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |                     copy_range_type()); | 
					
						
							| 
									
										
										
										
											2004-07-13 15:00:36 +00:00
										 |  |  |              | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |             transform_iter_type itEnd= | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |                 ::boost::make_transform_iterator(  | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |                     find_iterator_type(), | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |                     copy_range_type()); | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |             SequenceSequenceT Tmp(itBegin, itEnd); | 
					
						
							|  |  |  |                          | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             Result.swap(Tmp); | 
					
						
							|  |  |  |             return Result; | 
					
						
							| 
									
										
										
										
											2004-03-07 17:22:58 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | //  iterate split ---------------------------------------------------//
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //! Split find algorithm
 | 
					
						
							|  |  |  |         /*!
 | 
					
						
							|  |  |  |             This algorithm executes a given finder in iteration on the input, | 
					
						
							|  |  |  |             until the end of input is reached, or no match is found. | 
					
						
							|  |  |  |             Iteration is done using built-in find_iterator, so the real  | 
					
						
							|  |  |  |             searching is performed only when needed. | 
					
						
							|  |  |  |             Each match is used as a separator of segments. These segments are then | 
					
						
							|  |  |  |             returned in the result. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-05 15:14:40 +00:00
										 |  |  |             \param Result A 'container container' to contain the result of search. | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |                 Both outer and inner container must have constructor taking a pair | 
					
						
							|  |  |  |                 of iterators as an argument. | 
					
						
							|  |  |  |                 Typical type of the result is  | 
					
						
							|  |  |  |                     \c std::vector<boost::iterator_range<iterator>> | 
					
						
							|  |  |  |                 (each element of such a vector will container a range delimiting  | 
					
						
							|  |  |  |                 a match). | 
					
						
							|  |  |  |             \param Input A container which will be searched. | 
					
						
							|  |  |  |             \param Finder A finder object used for searching | 
					
						
							| 
									
										
										
										
											2012-07-05 15:14:40 +00:00
										 |  |  |             \return A reference to the result | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-15 21:48:25 +00:00
										 |  |  |             \note Prior content of the result will be overwritten. | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |         */ | 
					
						
							|  |  |  |         template<  | 
					
						
							|  |  |  |             typename SequenceSequenceT, | 
					
						
							| 
									
										
										
										
											2005-04-12 16:50:42 +00:00
										 |  |  |             typename RangeT, | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             typename FinderT > | 
					
						
							|  |  |  |         inline SequenceSequenceT& | 
					
						
							|  |  |  |         iter_split( | 
					
						
							|  |  |  |             SequenceSequenceT& Result, | 
					
						
							| 
									
										
										
										
											2005-04-12 16:50:42 +00:00
										 |  |  |             RangeT& Input, | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             FinderT Finder ) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |             BOOST_CONCEPT_ASSERT(( | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |                 FinderConcept<FinderT, | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |                 BOOST_STRING_TYPENAME range_iterator<RangeT>::type> | 
					
						
							|  |  |  |                 )); | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |             iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); | 
					
						
							| 
									
										
										
										
											2007-07-01 22:23:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             typedef BOOST_STRING_TYPENAME  | 
					
						
							| 
									
										
										
										
											2007-10-27 22:52:29 +00:00
										 |  |  |                 range_iterator<RangeT>::type input_iterator_type; | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             typedef split_iterator<input_iterator_type> find_iterator_type; | 
					
						
							|  |  |  |             typedef detail::copy_iterator_rangeF< | 
					
						
							|  |  |  |                 BOOST_STRING_TYPENAME  | 
					
						
							| 
									
										
										
										
											2005-01-21 16:45:29 +00:00
										 |  |  |                     range_value<SequenceSequenceT>::type, | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |                 input_iterator_type> copy_range_type; | 
					
						
							|  |  |  |              | 
					
						
							| 
									
										
										
										
											2008-06-17 21:04:00 +00:00
										 |  |  |             input_iterator_type InputEnd=::boost::end(lit_input); | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |             typedef transform_iterator<copy_range_type, find_iterator_type> | 
					
						
							|  |  |  |                 transform_iter_type; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |             transform_iter_type itBegin= | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |                 ::boost::make_transform_iterator(  | 
					
						
							| 
									
										
										
										
											2008-06-17 21:04:00 +00:00
										 |  |  |                     find_iterator_type( ::boost::begin(lit_input), InputEnd, Finder ), | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |                     copy_range_type() ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             transform_iter_type itEnd= | 
					
						
							| 
									
										
										
										
											2009-08-05 20:01:10 +00:00
										 |  |  |                 ::boost::make_transform_iterator(  | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |                     find_iterator_type(), | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |                     copy_range_type() ); | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |              | 
					
						
							| 
									
										
										
										
											2004-07-13 14:20:06 +00:00
										 |  |  |             SequenceSequenceT Tmp(itBegin, itEnd); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  |             Result.swap(Tmp); | 
					
						
							|  |  |  |             return Result; | 
					
						
							| 
									
										
										
										
											2004-03-07 17:22:58 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2004-03-04 22:12:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } // namespace algorithm
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // pull names to the boost namespace
 | 
					
						
							|  |  |  |     using algorithm::iter_find; | 
					
						
							|  |  |  |     using algorithm::iter_split; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace boost
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif  // BOOST_STRING_ITER_FIND_HPP
 |