Compare commits

..

25 Commits

Author SHA1 Message Date
d0af9f15ef bcbboost branch rebased on current release
[SVN r49389]
2008-10-19 14:43:01 +00:00
98a8b08afb Memory management fixes for is_any_of predicate merged from the trunk
[SVN r49172]
2008-10-07 21:59:57 +00:00
31777b28df Patches for Codegear C++ Builder 2009
[SVN r48981]
2008-09-27 08:59:20 +00:00
fc0f3dcffc Cummulative merge of updates from the main trunk
[SVN r46505]
2008-06-19 12:07:24 +00:00
822636418b Merged revisions 43211,43214-43219,43222-43225,43227-43238,43242,43244-43245,43249-43250,43257-43259,43261,43263,43265,43267-43268,43270-43271,43273,43275-43279,43284-43289,43291,43295,43297-43298,43304-43305,43307,43313,43315,43324,43326-43327,43331,43333,43339-43343,43345,43348,43350,43352-43353,43355-43356,43358,43360,43366-43367,43369-43370,43372-43376,43378-43389,43394,43396-43398,43400-43401,43403-43404,43406-43408,43413-43415,43417-43418,43420,43422-43423 via svnmerge from
https://svn.boost.org/svn/boost/trunk

........
  r43417 | danieljames | 2008-02-26 22:04:55 +0000 (Tue, 26 Feb 2008) | 2 lines
  
  Fix a link to Boost.Bimap.
........
  r43418 | danieljames | 2008-02-26 22:07:25 +0000 (Tue, 26 Feb 2008) | 2 lines
  
  Change another link that's no longer in the repository to link to the website.
........
  r43422 | danieljames | 2008-02-27 18:51:14 +0000 (Wed, 27 Feb 2008) | 1 line
  
  Fix broken copyright urls. Fixes #1573.
........
  r43423 | danieljames | 2008-02-27 19:22:01 +0000 (Wed, 27 Feb 2008) | 1 line
  
  Fix incorrect links to copyright of the form 'http:#www.boost.org
........


[SVN r43425]
2008-02-27 20:00:24 +00:00
352e16aade Merged revisions 43206,43208-43213 via svnmerge from
https://svn.boost.org/svn/boost/trunk

........
  r43206 | danieljames | 2008-02-10 09:55:03 +0000 (Sun, 10 Feb 2008) | 1 line
  
  Fix some broken links.
........
  r43209 | danieljames | 2008-02-10 14:56:22 +0000 (Sun, 10 Feb 2008) | 1 line
  
  Link to people pages on the website, as they've been removed from the download.
........
  r43210 | danieljames | 2008-02-10 15:02:17 +0000 (Sun, 10 Feb 2008) | 1 line
  
  Point links to the pages that used to be in 'more' to the site.
........
  r43212 | danieljames | 2008-02-10 16:10:16 +0000 (Sun, 10 Feb 2008) | 1 line
  
  Fix links on the home page as well.
........
  r43213 | danieljames | 2008-02-10 16:21:22 +0000 (Sun, 10 Feb 2008) | 1 line
  
  Generated documentation which is no longer generated.
........


[SVN r43214]
2008-02-10 16:39:38 +00:00
89c76ea1bb Full merge from trunk at revision 41356 of entire boost-root tree.
[SVN r41370]
2007-11-25 18:38:02 +00:00
50b5726a6f Full merge from trunk at revision 41356 of entire boost-root tree.
[SVN r41369]
2007-11-25 18:07:19 +00:00
d4b95734dd Starting point for releases
[SVN r39706]
2007-10-05 14:25:06 +00:00
d0bd40374e Merge from trunk
[SVN r39594]
2007-09-29 14:51:39 +00:00
5dd2a2bc42 Merge from trunk
[SVN r39533]
2007-09-25 22:53:44 +00:00
fa8fcd2e61 Branch for CodeGear (Borland) specific fixes
[SVN r39356]
2007-09-17 20:28:43 +00:00
05af96f84c This commit was manufactured by cvs2svn to create tag
'Version_1_34_1'.

[SVN r38286]
2007-07-24 19:28:14 +00:00
5bdbb2b308 Documentation for iter_find/iter_split added
[SVN r37842]
2007-06-01 13:50:51 +00:00
1a02969303 release notes - fix the incorrect functionname spelling
[SVN r37533]
2007-04-29 07:04:58 +00:00
6309379618 release notes for 1.34 added
[SVN r37532]
2007-04-29 07:02:21 +00:00
37581bac55 documentation typo fixed
[SVN r36843]
2007-01-30 07:59:28 +00:00
a71a4ed5b1 Merged copyright and license addition
[SVN r35907]
2006-11-07 19:27:00 +00:00
c509c3fbad Remove obsolete Boost.Build v1 files.
[SVN r35880]
2006-11-06 17:10:46 +00:00
d8683f2498 unused parameters removed
[SVN r35753]
2006-10-27 17:37:37 +00:00
7c0101aa51 Copyright added to index.html
unneeded file removed


[SVN r34908]
2006-08-20 20:14:48 +00:00
6f3e85528f License added to the xml documentation files
[SVN r34894]
2006-08-16 07:10:48 +00:00
8af639b7cf missing 'using' directives for join_if and join_if_regex added
missing #include <boost/algorithm/string/join.hpp> added to string_algo.hpp


[SVN r34122]
2006-05-30 19:13:08 +00:00
d9bc7e800b Merged patch from main trunk for borland by Nicola Musatti
[SVN r33723]
2006-04-17 17:16:11 +00:00
b4ed9beb90 This commit was manufactured by cvs2svn to create branch 'RC_1_34_0'.
[SVN r33417]
2006-03-21 02:26:31 +00:00
40 changed files with 569 additions and 1060 deletions

View File

@ -59,7 +59,7 @@ namespace boost {
{ {
return ::boost::algorithm::detail::transform_range_copy( return ::boost::algorithm::detail::transform_range_copy(
Output, Output,
::boost::as_literal(Input), as_literal(Input),
::boost::algorithm::detail::to_lowerF< ::boost::algorithm::detail::to_lowerF<
typename range_value<RangeT>::type >(Loc)); typename range_value<RangeT>::type >(Loc));
} }
@ -93,7 +93,7 @@ namespace boost {
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
::boost::algorithm::detail::transform_range( ::boost::algorithm::detail::transform_range(
::boost::as_literal(Input), as_literal(Input),
::boost::algorithm::detail::to_lowerF< ::boost::algorithm::detail::to_lowerF<
typename range_value<WritableRangeT>::type >(Loc)); typename range_value<WritableRangeT>::type >(Loc));
} }
@ -124,7 +124,7 @@ namespace boost {
{ {
return ::boost::algorithm::detail::transform_range_copy( return ::boost::algorithm::detail::transform_range_copy(
Output, Output,
::boost::as_literal(Input), as_literal(Input),
::boost::algorithm::detail::to_upperF< ::boost::algorithm::detail::to_upperF<
typename range_value<RangeT>::type >(Loc)); typename range_value<RangeT>::type >(Loc));
} }
@ -158,7 +158,7 @@ namespace boost {
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
::boost::algorithm::detail::transform_range( ::boost::algorithm::detail::transform_range(
::boost::as_literal(Input), as_literal(Input),
::boost::algorithm::detail::to_upperF< ::boost::algorithm::detail::to_upperF<
typename range_value<WritableRangeT>::type >(Loc)); typename range_value<WritableRangeT>::type >(Loc));
} }

View File

@ -202,7 +202,7 @@ namespace boost {
BOOST_STRING_TYPENAME range_value<RangeT>::type> BOOST_STRING_TYPENAME range_value<RangeT>::type>
is_any_of( const RangeT& Set ) is_any_of( const RangeT& Set )
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_set(boost::as_literal(Set)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_set(as_literal(Set));
return detail::is_any_ofF<BOOST_STRING_TYPENAME range_value<RangeT>::type>(lit_set); return detail::is_any_ofF<BOOST_STRING_TYPENAME range_value<RangeT>::type>(lit_set);
} }

View File

@ -31,7 +31,7 @@ namespace boost {
struct to_lowerF : public std::unary_function<CharT, CharT> struct to_lowerF : public std::unary_function<CharT, CharT>
{ {
// Constructor // Constructor
to_lowerF( const std::locale& Loc ) : m_Loc( &Loc ) {} to_lowerF( const std::locale& Loc ) : m_Loc( Loc ) {}
// Operation // Operation
CharT operator ()( CharT Ch ) const CharT operator ()( CharT Ch ) const
@ -39,11 +39,11 @@ namespace boost {
#if defined(__BORLANDC__) && (__BORLANDC__ >= 0x560) && (__BORLANDC__ <= 0x564) && !defined(_USE_OLD_RW_STL) #if defined(__BORLANDC__) && (__BORLANDC__ >= 0x560) && (__BORLANDC__ <= 0x564) && !defined(_USE_OLD_RW_STL)
return std::tolower( Ch); return std::tolower( Ch);
#else #else
return std::tolower<CharT>( Ch, *m_Loc ); return std::tolower<CharT>( Ch, m_Loc );
#endif #endif
} }
private: private:
const std::locale* m_Loc; const std::locale& m_Loc;
}; };
// a toupper functor // a toupper functor
@ -51,7 +51,7 @@ namespace boost {
struct to_upperF : public std::unary_function<CharT, CharT> struct to_upperF : public std::unary_function<CharT, CharT>
{ {
// Constructor // Constructor
to_upperF( const std::locale& Loc ) : m_Loc( &Loc ) {} to_upperF( const std::locale& Loc ) : m_Loc( Loc ) {}
// Operation // Operation
CharT operator ()( CharT Ch ) const CharT operator ()( CharT Ch ) const
@ -59,11 +59,11 @@ namespace boost {
#if defined(__BORLANDC__) && (__BORLANDC__ >= 0x560) && (__BORLANDC__ <= 0x564) && !defined(_USE_OLD_RW_STL) #if defined(__BORLANDC__) && (__BORLANDC__ >= 0x560) && (__BORLANDC__ <= 0x564) && !defined(_USE_OLD_RW_STL)
return std::toupper( Ch); return std::toupper( Ch);
#else #else
return std::toupper<CharT>( Ch, *m_Loc ); return std::toupper<CharT>( Ch, m_Loc );
#endif #endif
} }
private: private:
const std::locale* m_Loc; const std::locale& m_Loc;
}; };
#if BOOST_WORKAROUND(BOOST_MSVC, >= 1400) #if BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
@ -105,10 +105,10 @@ namespace boost {
FunctorT Functor) FunctorT Functor)
{ {
return SequenceT( return SequenceT(
::boost::make_transform_iterator( make_transform_iterator(
::boost::begin(Input), ::boost::begin(Input),
Functor), Functor),
::boost::make_transform_iterator( make_transform_iterator(
::boost::end(Input), ::boost::end(Input),
Functor)); Functor));
} }

View File

@ -32,8 +32,8 @@ namespace boost {
struct is_classifiedF : struct is_classifiedF :
public predicate_facade<is_classifiedF> public predicate_facade<is_classifiedF>
{ {
// Boost.ResultOf support // Boost.Lambda support
typedef bool result_type; template <class Args> struct sig { typedef bool type; };
// Constructor from a locale // Constructor from a locale
is_classifiedF(std::ctype_base::mask Type, std::locale const & Loc = std::locale()) : is_classifiedF(std::ctype_base::mask Type, std::locale const & Loc = std::locale()) :
@ -72,8 +72,8 @@ namespace boost {
typedef typename ::boost::remove_const<CharT>::type set_value_type; typedef typename ::boost::remove_const<CharT>::type set_value_type;
public: public:
// Boost.ResultOf support // Boost.Lambda support
typedef bool result_type; template <class Args> struct sig { typedef bool type; };
// Constructor // Constructor
template<typename RangeT> template<typename RangeT>
@ -171,7 +171,7 @@ namespace boost {
// Check what kind of storage are we using right now // Check what kind of storage are we using right now
if(use_fixed_storage(m_Size)) if(use_fixed_storage(m_Size))
{ {
// Using fixed storage, allocate new // Using fixed storage, allocate new
set_value_type* pTemp=new set_value_type[Other.m_Size]; set_value_type* pTemp=new set_value_type[Other.m_Size];
DestStorage=pTemp; DestStorage=pTemp;
m_Storage.m_dynSet=pTemp; m_Storage.m_dynSet=pTemp;
@ -253,8 +253,8 @@ namespace boost {
struct is_from_rangeF : struct is_from_rangeF :
public predicate_facade< is_from_rangeF<CharT> > public predicate_facade< is_from_rangeF<CharT> >
{ {
// Boost.ResultOf support // Boost.Lambda support
typedef bool result_type; template <class Args> struct sig { typedef bool type; };
// Constructor // Constructor
is_from_rangeF( CharT From, CharT To ) : m_From(From), m_To(To) {} is_from_rangeF( CharT From, CharT To ) : m_From(From), m_To(To) {}
@ -278,8 +278,8 @@ namespace boost {
{ {
public: public:
// Boost.ResultOf support // Boost.Lambda support
typedef bool result_type; template <class Args> struct sig { typedef bool type; };
// Constructor // Constructor
pred_andF( Pred1T Pred1, Pred2T Pred2 ) : pred_andF( Pred1T Pred1, Pred2T Pred2 ) :
@ -303,8 +303,8 @@ namespace boost {
public predicate_facade< pred_orF<Pred1T,Pred2T> > public predicate_facade< pred_orF<Pred1T,Pred2T> >
{ {
public: public:
// Boost.ResultOf support // Boost.Lambda support
typedef bool result_type; template <class Args> struct sig { typedef bool type; };
// Constructor // Constructor
pred_orF( Pred1T Pred1, Pred2T Pred2 ) : pred_orF( Pred1T Pred1, Pred2T Pred2 ) :
@ -328,8 +328,8 @@ namespace boost {
public predicate_facade< pred_notF<PredT> > public predicate_facade< pred_notF<PredT> >
{ {
public: public:
// Boost.ResultOf support // Boost.Lambda support
typedef bool result_type; template <class Args> struct sig { typedef bool type; };
// Constructor // Constructor
pred_notF( PredT Pred ) : m_Pred(Pred) {} pred_notF( PredT Pred ) : m_Pred(Pred) {}

View File

@ -24,7 +24,26 @@ namespace boost {
// find_format_copy (iterator variant) implementation -------------------------------// // find_format_copy (iterator variant) implementation -------------------------------//
template< template<
typename OutputIteratorT,
typename InputT,
typename FormatterT,
typename FindResultT >
inline OutputIteratorT find_format_copy_impl(
OutputIteratorT Output,
const InputT& Input,
FormatterT Formatter,
const FindResultT& FindResult )
{
return find_format_copy_impl2(
Output,
Input,
Formatter,
FindResult,
Formatter(FindResult) );
}
template<
typename OutputIteratorT, typename OutputIteratorT,
typename InputT, typename InputT,
typename FormatterT, typename FormatterT,
@ -49,48 +68,40 @@ namespace boost {
if ( !M ) if ( !M )
{ {
// Match not found - return original sequence // Match not found - return original sequence
Output = std::copy( ::boost::begin(Input), ::boost::end(Input), Output ); std::copy( ::boost::begin(Input), ::boost::end(Input), Output );
return Output; return Output;
} }
// Copy the beginning of the sequence // Copy the beginning of the sequence
Output = std::copy( ::boost::begin(Input), ::boost::begin(M), Output ); std::copy( ::boost::begin(Input), ::boost::begin(M), Output );
// Format find result // Format find result
// Copy formated result // Copy formated result
Output = std::copy( ::boost::begin(M.format_result()), ::boost::end(M.format_result()), Output ); std::copy( ::boost::begin(M.format_result()), ::boost::end(M.format_result()), Output );
// Copy the rest of the sequence // Copy the rest of the sequence
Output = std::copy( M.end(), ::boost::end(Input), Output ); std::copy( M.end(), ::boost::end(Input), Output );
return Output; return Output;
} }
template<
typename OutputIteratorT,
typename InputT,
typename FormatterT,
typename FindResultT >
inline OutputIteratorT find_format_copy_impl(
OutputIteratorT Output,
const InputT& Input,
FormatterT Formatter,
const FindResultT& FindResult )
{
if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) {
return ::boost::algorithm::detail::find_format_copy_impl2(
Output,
Input,
Formatter,
FindResult,
Formatter(FindResult) );
} else {
return std::copy( ::boost::begin(Input), ::boost::end(Input), Output );
}
}
// find_format_copy implementation --------------------------------------------------// // find_format_copy implementation --------------------------------------------------//
template< template<
typename InputT,
typename FormatterT,
typename FindResultT >
inline InputT find_format_copy_impl(
const InputT& Input,
FormatterT Formatter,
const FindResultT& FindResult)
{
return find_format_copy_impl2(
Input,
Formatter,
FindResult,
Formatter(FindResult) );
}
template<
typename InputT, typename InputT,
typename FormatterT, typename FormatterT,
typename FindResultT, typename FindResultT,
@ -127,28 +138,24 @@ namespace boost {
return Output; return Output;
} }
template< // replace implementation ----------------------------------------------------//
typename InputT,
template<
typename InputT,
typename FormatterT, typename FormatterT,
typename FindResultT > typename FindResultT >
inline InputT find_format_copy_impl( inline void find_format_impl(
const InputT& Input, InputT& Input,
FormatterT Formatter, FormatterT Formatter,
const FindResultT& FindResult) const FindResultT& FindResult)
{ {
if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) { find_format_impl2(
return ::boost::algorithm::detail::find_format_copy_impl2( Input,
Input, Formatter,
Formatter, FindResult,
FindResult, Formatter(FindResult) );
Formatter(FindResult) );
} else {
return Input;
}
} }
// replace implementation ----------------------------------------------------//
template< template<
typename InputT, typename InputT,
typename FormatterT, typename FormatterT,
@ -176,25 +183,7 @@ namespace boost {
} }
// Replace match // Replace match
::boost::algorithm::detail::replace( Input, M.begin(), M.end(), M.format_result() ); replace( Input, M.begin(), M.end(), M.format_result() );
}
template<
typename InputT,
typename FormatterT,
typename FindResultT >
inline void find_format_impl(
InputT& Input,
FormatterT Formatter,
const FindResultT& FindResult)
{
if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) {
::boost::algorithm::detail::find_format_impl2(
Input,
Formatter,
FindResult,
Formatter(FindResult) );
}
} }
} // namespace detail } // namespace detail

View File

@ -24,7 +24,29 @@ namespace boost {
// find_format_all_copy (iterator variant) implementation ---------------------------// // find_format_all_copy (iterator variant) implementation ---------------------------//
template< 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 )
{
return find_format_all_copy_impl2(
Output,
Input,
Finder,
Formatter,
FindResult,
Formatter(FindResult) );
}
template<
typename OutputIteratorT, typename OutputIteratorT,
typename InputT, typename InputT,
typename FinderT, typename FinderT,
@ -57,9 +79,9 @@ namespace boost {
while( M ) while( M )
{ {
// Copy the beginning of the sequence // Copy the beginning of the sequence
Output = std::copy( LastMatch, M.begin(), Output ); std::copy( LastMatch, M.begin(), Output );
// Copy formated result // Copy formated result
Output = std::copy( ::boost::begin(M.format_result()), ::boost::end(M.format_result()), Output ); std::copy( ::boost::begin(M.format_result()), ::boost::end(M.format_result()), Output );
// Proceed to the next match // Proceed to the next match
LastMatch=M.end(); LastMatch=M.end();
@ -67,40 +89,33 @@ namespace boost {
} }
// Copy the rest of the sequence // Copy the rest of the sequence
Output = std::copy( LastMatch, ::boost::end(Input), Output ); std::copy( LastMatch, ::boost::end(Input), Output );
return Output; return Output;
} }
// find_format_all_copy implementation ----------------------------------------------//
template< template<
typename OutputIteratorT, typename InputT,
typename InputT,
typename FinderT, typename FinderT,
typename FormatterT, typename FormatterT,
typename FindResultT > typename FindResultT >
inline OutputIteratorT find_format_all_copy_impl( inline InputT find_format_all_copy_impl(
OutputIteratorT Output,
const InputT& Input, const InputT& Input,
FinderT Finder, FinderT Finder,
FormatterT Formatter, FormatterT Formatter,
const FindResultT& FindResult ) const FindResultT& FindResult)
{ {
if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) { return find_format_all_copy_impl2(
return ::boost::algorithm::detail::find_format_all_copy_impl2( Input,
Output, Finder,
Input, Formatter,
Finder, FindResult,
Formatter, Formatter(FindResult) );
FindResult,
Formatter(FindResult) );
} else {
return std::copy( ::boost::begin(Input), ::boost::end(Input), Output );
}
} }
// find_format_all_copy implementation ----------------------------------------------// template<
template<
typename InputT, typename InputT,
typename FinderT, typename FinderT,
typename FormatterT, typename FormatterT,
@ -144,36 +159,32 @@ namespace boost {
} }
// Copy the rest of the sequence // Copy the rest of the sequence
::boost::algorithm::detail::insert( Output, ::boost::end(Output), LastMatch, ::boost::end(Input) ); insert( Output, ::boost::end(Output), LastMatch, ::boost::end(Input) );
return Output; return Output;
} }
template< // find_format_all implementation ------------------------------------------------//
typename InputT,
template<
typename InputT,
typename FinderT, typename FinderT,
typename FormatterT, typename FormatterT,
typename FindResultT > typename FindResultT >
inline InputT find_format_all_copy_impl( inline void find_format_all_impl(
const InputT& Input, InputT& Input,
FinderT Finder, FinderT Finder,
FormatterT Formatter, FormatterT Formatter,
const FindResultT& FindResult) FindResultT FindResult)
{ {
if( ::boost::algorithm::detail::check_find_result(Input, FindResult) ) { find_format_all_impl2(
return ::boost::algorithm::detail::find_format_all_copy_impl2( Input,
Input, Finder,
Finder, Formatter,
Formatter, FindResult,
FindResult, Formatter(FindResult) );
Formatter(FindResult) );
} else {
return Input;
}
} }
// find_format_all implementation ------------------------------------------------//
template< template<
typename InputT, typename InputT,
typename FinderT, typename FinderT,
@ -219,14 +230,14 @@ namespace boost {
SearchIt=M.end(); SearchIt=M.end();
// Copy formated replace to the storage // Copy formated replace to the storage
::boost::algorithm::detail::copy_to_storage( Storage, M.format_result() ); copy_to_storage( Storage, M.format_result() );
// Find range for a next match // Find range for a next match
M=Finder( SearchIt, ::boost::end(Input) ); M=Finder( SearchIt, ::boost::end(Input) );
} }
// process the last segment // process the last segment
InsertIt=::boost::algorithm::detail::process_segment( InsertIt=process_segment(
Storage, Storage,
Input, Input,
InsertIt, InsertIt,
@ -236,33 +247,12 @@ namespace boost {
if ( Storage.empty() ) if ( Storage.empty() )
{ {
// Truncate input // Truncate input
::boost::algorithm::detail::erase( Input, InsertIt, ::boost::end(Input) ); erase( Input, InsertIt, ::boost::end(Input) );
} }
else else
{ {
// Copy remaining data to the end of input // Copy remaining data to the end of input
::boost::algorithm::detail::insert( Input, ::boost::end(Input), Storage.begin(), Storage.end() ); 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) );
} }
} }

View File

@ -52,9 +52,7 @@ namespace boost {
find_format_store& operator=( FindResultT FindResult ) find_format_store& operator=( FindResultT FindResult )
{ {
iterator_range<ForwardIteratorT>::operator=(FindResult); iterator_range<ForwardIteratorT>::operator=(FindResult);
if( !this->empty() ) { m_FormatResult=m_Formatter(FindResult);
m_FormatResult=m_Formatter(FindResult);
}
return *this; return *this;
} }
@ -70,15 +68,6 @@ namespace boost {
const formatter_type& m_Formatter; const formatter_type& m_Formatter;
}; };
template<typename InputT, typename FindResultT>
bool check_find_result(InputT&, FindResultT& FindResult)
{
typedef BOOST_STRING_TYPENAME
range_const_iterator<InputT>::type input_iterator_type;
iterator_range<input_iterator_type> ResultRange(FindResult);
return !ResultRange.empty();
}
#if BOOST_WORKAROUND(BOOST_MSVC, >= 1400) #if BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
#pragma warning(pop) #pragma warning(pop)
#endif #endif

View File

@ -382,7 +382,7 @@ namespace boost {
typedef BOOST_STRING_TYPENAME boost::detail:: typedef BOOST_STRING_TYPENAME boost::detail::
iterator_traits<ForwardIteratorT>::iterator_category category; iterator_traits<ForwardIteratorT>::iterator_category category;
return ::boost::algorithm::detail::find_head_impl( Begin, End, N, category() ); return find_head_impl( Begin, End, N, category() );
} }
template< typename ForwardIteratorT > template< typename ForwardIteratorT >
@ -456,7 +456,7 @@ namespace boost {
typedef BOOST_STRING_TYPENAME boost::detail:: typedef BOOST_STRING_TYPENAME boost::detail::
iterator_traits<ForwardIteratorT>::iterator_category category; iterator_traits<ForwardIteratorT>::iterator_category category;
return ::boost::algorithm::detail::find_tail_impl( Begin, End, N, category() ); return find_tail_impl( Begin, End, N, category() );
} }
@ -484,14 +484,14 @@ namespace boost {
{ {
if(m_N>=0) if(m_N>=0)
{ {
return ::boost::algorithm::detail::find_head_impl( Begin, End, m_N ); return find_head_impl( Begin, End, m_N );
} }
else else
{ {
iterator_range<ForwardIteratorT> Res= iterator_range<ForwardIteratorT> Res=
::boost::algorithm::detail::find_tail_impl( Begin, End, -m_N ); find_tail_impl( Begin, End, -m_N );
return ::boost::make_iterator_range(Begin, Res.begin()); return make_iterator_range(Begin, Res.begin());
} }
} }
@ -522,14 +522,14 @@ namespace boost {
{ {
if(m_N>=0) if(m_N>=0)
{ {
return ::boost::algorithm::detail::find_tail_impl( Begin, End, m_N ); return find_tail_impl( Begin, End, m_N );
} }
else else
{ {
iterator_range<ForwardIteratorT> Res= iterator_range<ForwardIteratorT> Res=
::boost::algorithm::detail::find_head_impl( Begin, End, -m_N ); find_head_impl( Begin, End, -m_N );
return ::boost::make_iterator_range(Res.end(), End); return make_iterator_range(Res.end(), End);
} }
} }

View File

@ -98,7 +98,7 @@ namespace boost {
// instantiate match result // instantiate match result
match_results<input_iterator_type> result; match_results<input_iterator_type> result;
// search for a match // search for a match
if ( ::boost::regex_search( Begin, End, result, m_Rx, m_MatchFlags ) ) if ( regex_search( Begin, End, result, m_Rx, m_MatchFlags ) )
{ {
// construct a result // construct a result
return result_type( result ); return result_type( result );

View File

@ -87,31 +87,6 @@ namespace boost {
} }
}; };
// dissect format functor ----------------------------------------------------//
// dissect format functor
template<typename FinderT>
struct dissect_formatF
{
public:
// Construction
dissect_formatF(FinderT Finder) :
m_Finder(Finder) {}
// Operation
template<typename RangeT>
inline iterator_range<
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type>
operator()(const RangeT& Replace) const
{
return m_Finder(::boost::begin(Replace), ::boost::end(Replace));
}
private:
FinderT m_Finder;
};
} // namespace detail } // namespace detail
} // namespace algorithm } // namespace algorithm
} // namespace boost } // namespace boost

View File

@ -63,7 +63,7 @@ namespace boost {
iterator_range<ForwardIterator1T> Result iterator_range<ForwardIterator1T> Result
=last_finder( =last_finder(
::boost::make_iterator_range(SubBegin, SubEnd), make_iterator_range(SubBegin, SubEnd),
Comp)(Begin, End); Comp)(Begin, End);
return !Result.empty() && Result.end()==End; return !Result.empty() && Result.end()==End;

View File

@ -68,7 +68,7 @@ namespace boost {
ForwardIteratorT SegmentEnd ) ForwardIteratorT SegmentEnd )
{ {
// Copy data from the storage until the beginning of the segment // Copy data from the storage until the beginning of the segment
ForwardIteratorT It=::boost::algorithm::detail::move_from_storage( Storage, InsertIt, SegmentBegin ); ForwardIteratorT It=move_from_storage( Storage, InsertIt, SegmentBegin );
// 3 cases are possible : // 3 cases are possible :
// a) Storage is empty, It==SegmentBegin // a) Storage is empty, It==SegmentBegin
@ -125,7 +125,7 @@ namespace boost {
{ {
// Call replace to do the job // Call replace to do the job
::boost::algorithm::detail::replace( Input, InsertIt, SegmentBegin, Storage ); replace( Input, InsertIt, SegmentBegin, Storage );
// Empty the storage // Empty the storage
Storage.clear(); Storage.clear();
// Iterators were not changed, simply return the end of segment // Iterators were not changed, simply return the end of segment

View File

@ -41,7 +41,7 @@ namespace boost {
BOOST_STRING_TYPENAME InputT::iterator At, BOOST_STRING_TYPENAME InputT::iterator At,
const InsertT& Insert ) const InsertT& Insert )
{ {
::boost::algorithm::detail::insert( Input, At, ::boost::begin(Insert), ::boost::end(Insert) ); insert( Input, At, ::boost::begin(Insert), ::boost::end(Insert) );
} }
// erase helper ---------------------------------------------------// // erase helper ---------------------------------------------------//
@ -184,11 +184,11 @@ namespace boost {
{ {
if(From!=To) if(From!=To)
{ {
::boost::algorithm::detail::replace( Input, From, To, ::boost::begin(Insert), ::boost::end(Insert) ); replace( Input, From, To, ::boost::begin(Insert), ::boost::end(Insert) );
} }
else else
{ {
::boost::algorithm::detail::insert( Input, From, ::boost::begin(Insert), ::boost::end(Insert) ); insert( Input, From, ::boost::begin(Insert), ::boost::end(Insert) );
} }
} }

View File

@ -20,6 +20,36 @@ namespace boost {
// trim iterator helper -----------------------------------------------// // trim iterator helper -----------------------------------------------//
// Search for first non matching character from the beginning of the sequence
template< typename ForwardIteratorT, typename PredicateT >
inline ForwardIteratorT trim_begin(
ForwardIteratorT InBegin,
ForwardIteratorT InEnd,
PredicateT IsSpace )
{
ForwardIteratorT It=InBegin;
for(; It!=InEnd; ++It )
{
if (!IsSpace(*It))
return It;
}
return It;
}
// Search for first non matching character from the end of the sequence
template< typename ForwardIteratorT, typename PredicateT >
inline ForwardIteratorT trim_end(
ForwardIteratorT InBegin,
ForwardIteratorT InEnd,
PredicateT IsSpace )
{
typedef BOOST_STRING_TYPENAME boost::detail::
iterator_traits<ForwardIteratorT>::iterator_category category;
return trim_end_iter_select( InBegin, InEnd, IsSpace, category() );
}
template< typename ForwardIteratorT, typename PredicateT > template< typename ForwardIteratorT, typename PredicateT >
inline ForwardIteratorT trim_end_iter_select( inline ForwardIteratorT trim_end_iter_select(
ForwardIteratorT InBegin, ForwardIteratorT InBegin,
@ -56,36 +86,6 @@ namespace boost {
return InBegin; return InBegin;
} }
// Search for first non matching character from the beginning of the sequence
template< typename ForwardIteratorT, typename PredicateT >
inline ForwardIteratorT trim_begin(
ForwardIteratorT InBegin,
ForwardIteratorT InEnd,
PredicateT IsSpace )
{
ForwardIteratorT It=InBegin;
for(; It!=InEnd; ++It )
{
if (!IsSpace(*It))
return It;
}
return It;
}
// Search for first non matching character from the end of the sequence
template< typename ForwardIteratorT, typename PredicateT >
inline ForwardIteratorT trim_end(
ForwardIteratorT InBegin,
ForwardIteratorT InEnd,
PredicateT IsSpace )
{
typedef BOOST_STRING_TYPENAME boost::detail::
iterator_traits<ForwardIteratorT>::iterator_category category;
return ::boost::algorithm::detail::trim_end_iter_select( InBegin, InEnd, IsSpace, category() );
}
} // namespace detail } // namespace detail
} // namespace algorithm } // namespace algorithm

View File

@ -54,11 +54,11 @@ namespace boost {
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type>& SearchRange ) range_const_iterator<RangeT>::type>& SearchRange )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::range_finder(SearchRange), range_finder(SearchRange),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase range algorithm //! Erase range algorithm
@ -72,10 +72,10 @@ namespace boost {
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<SequenceT>::type>& SearchRange ) range_const_iterator<SequenceT>::type>& SearchRange )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::range_finder(SearchRange), range_finder(SearchRange),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase range algorithm //! Erase range algorithm
@ -93,10 +93,10 @@ namespace boost {
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_iterator<SequenceT>::type>& SearchRange ) range_iterator<SequenceT>::type>& SearchRange )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::range_finder(SearchRange), range_finder(SearchRange),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_first --------------------------------------------------------// // erase_first --------------------------------------------------------//
@ -124,11 +124,11 @@ namespace boost {
const Range1T& Input, const Range1T& Input,
const Range2T& Search ) const Range2T& Search )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase first algorithm //! Erase first algorithm
@ -140,10 +140,10 @@ namespace boost {
const SequenceT& Input, const SequenceT& Input,
const RangeT& Search ) const RangeT& Search )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase first algorithm //! Erase first algorithm
@ -159,10 +159,10 @@ namespace boost {
SequenceT& Input, SequenceT& Input,
const RangeT& Search ) const RangeT& Search )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_first ( case insensitive ) ------------------------------------// // erase_first ( case insensitive ) ------------------------------------//
@ -193,11 +193,11 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase first algorithm ( case insensitive ) //! Erase first algorithm ( case insensitive )
@ -210,10 +210,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase first algorithm ( case insensitive ) //! Erase first algorithm ( case insensitive )
@ -231,10 +231,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_last --------------------------------------------------------// // erase_last --------------------------------------------------------//
@ -262,11 +262,11 @@ namespace boost {
const Range1T& Input, const Range1T& Input,
const Range2T& Search ) const Range2T& Search )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::last_finder(Search), last_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase last algorithm //! Erase last algorithm
@ -278,10 +278,10 @@ namespace boost {
const SequenceT& Input, const SequenceT& Input,
const RangeT& Search ) const RangeT& Search )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::last_finder(Search), last_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase last algorithm //! Erase last algorithm
@ -297,10 +297,10 @@ namespace boost {
SequenceT& Input, SequenceT& Input,
const RangeT& Search ) const RangeT& Search )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::last_finder(Search), last_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_last ( case insensitive ) ------------------------------------// // erase_last ( case insensitive ) ------------------------------------//
@ -331,11 +331,11 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::last_finder(Search, is_iequal(Loc)), last_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase last algorithm ( case insensitive ) //! Erase last algorithm ( case insensitive )
@ -348,10 +348,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::last_finder(Search, is_iequal(Loc)), last_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase last algorithm ( case insensitive ) //! Erase last algorithm ( case insensitive )
@ -369,10 +369,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::last_finder(Search, is_iequal(Loc)), last_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_nth --------------------------------------------------------------------// // erase_nth --------------------------------------------------------------------//
@ -404,11 +404,11 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
int Nth ) int Nth )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::nth_finder(Search, Nth), nth_finder(Search, Nth),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase nth algorithm //! Erase nth algorithm
@ -421,10 +421,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
int Nth ) int Nth )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth), nth_finder(Search, Nth),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase nth algorithm //! Erase nth algorithm
@ -443,10 +443,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
int Nth ) int Nth )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth), nth_finder(Search, Nth),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_nth ( case insensitive ) ---------------------------------------------// // erase_nth ( case insensitive ) ---------------------------------------------//
@ -480,11 +480,11 @@ namespace boost {
int Nth, int Nth,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::nth_finder(Search, Nth, is_iequal(Loc)), nth_finder(Search, Nth, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase nth algorithm //! Erase nth algorithm
@ -498,9 +498,9 @@ namespace boost {
int Nth, int Nth,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth, is_iequal(Loc)), nth_finder(Search, Nth, is_iequal(Loc)),
empty_formatter(Input) ); empty_formatter(Input) );
} }
@ -522,10 +522,10 @@ namespace boost {
int Nth, int Nth,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth, is_iequal(Loc)), nth_finder(Search, Nth, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
@ -555,11 +555,11 @@ namespace boost {
const Range1T& Input, const Range1T& Input,
const Range2T& Search ) const Range2T& Search )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase all algorithm //! Erase all algorithm
@ -571,10 +571,10 @@ namespace boost {
const SequenceT& Input, const SequenceT& Input,
const RangeT& Search ) const RangeT& Search )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase all algorithm //! Erase all algorithm
@ -590,10 +590,10 @@ namespace boost {
SequenceT& Input, SequenceT& Input,
const RangeT& Search ) const RangeT& Search )
{ {
::boost::algorithm::find_format_all( find_format_all(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_all ( case insensitive ) ------------------------------------// // erase_all ( case insensitive ) ------------------------------------//
@ -624,11 +624,11 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase all algorithm ( case insensitive ) //! Erase all algorithm ( case insensitive )
@ -641,10 +641,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
//! Erase all algorithm ( case insensitive ) //! Erase all algorithm ( case insensitive )
@ -662,10 +662,10 @@ namespace boost {
const RangeT& Search, const RangeT& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format_all( find_format_all(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::empty_formatter(Input) ); empty_formatter(Input) );
} }
// erase_head --------------------------------------------------------------------// // erase_head --------------------------------------------------------------------//
@ -696,11 +696,11 @@ namespace boost {
const RangeT& Input, const RangeT& Input,
int N ) int N )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::head_finder(N), head_finder(N),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase head algorithm //! Erase head algorithm
@ -712,10 +712,10 @@ namespace boost {
const SequenceT& Input, const SequenceT& Input,
int N ) int N )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::head_finder(N), head_finder(N),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase head algorithm //! Erase head algorithm
@ -734,10 +734,10 @@ namespace boost {
SequenceT& Input, SequenceT& Input,
int N ) int N )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::head_finder(N), head_finder(N),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
// erase_tail --------------------------------------------------------------------// // erase_tail --------------------------------------------------------------------//
@ -752,7 +752,7 @@ namespace boost {
\param Output An output iterator to which the result will be copied \param Output An output iterator to which the result will be copied
\param Input An input string \param Input An input string
\param N Length of the tail. \param N Length of the head.
For N>=0, at most N characters are extracted. For N>=0, at most N characters are extracted.
For N<0, size(Input)-|N| characters are extracted. For N<0, size(Input)-|N| characters are extracted.
\return An output iterator pointing just after the last inserted character or \return An output iterator pointing just after the last inserted character or
@ -768,11 +768,11 @@ namespace boost {
const RangeT& Input, const RangeT& Input,
int N ) int N )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::tail_finder(N), tail_finder(N),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase tail algorithm //! Erase tail algorithm
@ -784,10 +784,10 @@ namespace boost {
const SequenceT& Input, const SequenceT& Input,
int N ) int N )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::tail_finder(N), tail_finder(N),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase tail algorithm //! Erase tail algorithm
@ -797,7 +797,7 @@ namespace boost {
considered to be the tail. The input sequence is modified in-place. considered to be the tail. The input sequence is modified in-place.
\param Input An input string \param Input An input string
\param N Length of the tail \param N Length of the head
For N>=0, at most N characters are extracted. For N>=0, at most N characters are extracted.
For N<0, size(Input)-|N| characters are extracted. For N<0, size(Input)-|N| characters are extracted.
*/ */
@ -806,10 +806,10 @@ namespace boost {
SequenceT& Input, SequenceT& Input,
int N ) int N )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::tail_finder(N), tail_finder(N),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
} // namespace algorithm } // namespace algorithm

View File

@ -53,7 +53,7 @@ namespace boost {
RangeT& Input, RangeT& Input,
const FinderT& Finder) const FinderT& Finder)
{ {
iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(as_literal(Input));
return Finder(::boost::begin(lit_input),::boost::end(lit_input)); return Finder(::boost::begin(lit_input),::boost::end(lit_input));
} }
@ -81,7 +81,7 @@ namespace boost {
Range1T& Input, Range1T& Input,
const Range2T& Search) const Range2T& Search)
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::first_finder(Search)); return find(Input, first_finder(Search));
} }
//! Find first algorithm ( case insensitive ) //! Find first algorithm ( case insensitive )
@ -108,7 +108,7 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::first_finder(Search,is_iequal(Loc))); return find(Input, first_finder(Search,is_iequal(Loc)));
} }
// find_last -----------------------------------------------// // find_last -----------------------------------------------//
@ -134,7 +134,7 @@ namespace boost {
Range1T& Input, Range1T& Input,
const Range2T& Search) const Range2T& Search)
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::last_finder(Search)); return find(Input, last_finder(Search));
} }
//! Find last algorithm ( case insensitive ) //! Find last algorithm ( case insensitive )
@ -161,7 +161,7 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::last_finder(Search, is_iequal(Loc))); return find(Input, last_finder(Search, is_iequal(Loc)));
} }
// find_nth ----------------------------------------------------------------------// // find_nth ----------------------------------------------------------------------//
@ -189,7 +189,7 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
int Nth) int Nth)
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::nth_finder(Search,Nth)); return find(Input, nth_finder(Search,Nth));
} }
//! Find n-th algorithm ( case insensitive ). //! Find n-th algorithm ( case insensitive ).
@ -220,7 +220,7 @@ namespace boost {
int Nth, int Nth,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::nth_finder(Search,Nth,is_iequal(Loc))); return find(Input, nth_finder(Search,Nth,is_iequal(Loc)));
} }
// find_head ----------------------------------------------------------------------// // find_head ----------------------------------------------------------------------//
@ -250,14 +250,14 @@ namespace boost {
RangeT& Input, RangeT& Input,
int N) int N)
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::head_finder(N)); return find(Input, head_finder(N));
} }
// find_tail ----------------------------------------------------------------------// // find_tail ----------------------------------------------------------------------//
//! Find tail algorithm //! Find tail algorithm
/*! /*!
Get the tail of the input. Tail is a suffix of the string of the Get the head of the input. Head is a suffix of the string of the
given size. If the input is shorter then required, whole input if considered given size. If the input is shorter then required, whole input if considered
to be the tail. to be the tail.
@ -281,7 +281,7 @@ namespace boost {
RangeT& Input, RangeT& Input,
int N) int N)
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::tail_finder(N)); return find(Input, tail_finder(N));
} }
// find_token --------------------------------------------------------------------// // find_token --------------------------------------------------------------------//
@ -311,7 +311,7 @@ namespace boost {
PredicateT Pred, PredicateT Pred,
token_compress_mode_type eCompress=token_compress_off) token_compress_mode_type eCompress=token_compress_off)
{ {
return ::boost::algorithm::find(Input, ::boost::algorithm::token_finder(Pred, eCompress)); return find(Input, token_finder(Pred, eCompress));
} }
} // namespace algorithm } // namespace algorithm

View File

@ -62,18 +62,15 @@ namespace boost {
FormatterT Formatter ) FormatterT Formatter )
{ {
// Concept check // Concept check
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept< FinderConcept<FinderT,
FinderT, BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >();
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> function_requires<
));
BOOST_CONCEPT_ASSERT((
FormatterConcept< FormatterConcept<
FormatterT, FormatterT,
FinderT,BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> FinderT,BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >();
));
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_input(as_literal(Input));
return detail::find_format_copy_impl( return detail::find_format_copy_impl(
Output, Output,
@ -96,16 +93,13 @@ namespace boost {
FormatterT Formatter ) FormatterT Formatter )
{ {
// Concept check // Concept check
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept< FinderConcept<FinderT,
FinderT, BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> function_requires<
));
BOOST_CONCEPT_ASSERT((
FormatterConcept< FormatterConcept<
FormatterT, FormatterT,
FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
));
return detail::find_format_copy_impl( return detail::find_format_copy_impl(
Input, Input,
@ -132,16 +126,13 @@ namespace boost {
FormatterT Formatter) FormatterT Formatter)
{ {
// Concept check // Concept check
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept< FinderConcept<FinderT,
FinderT, BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> function_requires<
));
BOOST_CONCEPT_ASSERT((
FormatterConcept< FormatterConcept<
FormatterT, FormatterT,
FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
));
detail::find_format_impl( detail::find_format_impl(
Input, Input,
@ -181,18 +172,15 @@ namespace boost {
FormatterT Formatter) FormatterT Formatter)
{ {
// Concept check // Concept check
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept< FinderConcept<FinderT,
FinderT, BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >();
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> function_requires<
));
BOOST_CONCEPT_ASSERT((
FormatterConcept< FormatterConcept<
FormatterT, FormatterT,
FinderT,BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> FinderT,BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >();
));
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_input(as_literal(Input));
return detail::find_format_all_copy_impl( return detail::find_format_all_copy_impl(
Output, Output,
@ -216,16 +204,13 @@ namespace boost {
FormatterT Formatter ) FormatterT Formatter )
{ {
// Concept check // Concept check
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept< FinderConcept<FinderT,
FinderT, BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> function_requires<
));
BOOST_CONCEPT_ASSERT((
FormatterConcept< FormatterConcept<
FormatterT, FormatterT,
FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
));
return detail::find_format_all_copy_impl( return detail::find_format_all_copy_impl(
Input, Input,
@ -254,16 +239,13 @@ namespace boost {
FormatterT Formatter ) FormatterT Formatter )
{ {
// Concept check // Concept check
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept< FinderConcept<FinderT,
FinderT, BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> function_requires<
));
BOOST_CONCEPT_ASSERT((
FormatterConcept< FormatterConcept<
FormatterT, FormatterT,
FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> FinderT,BOOST_STRING_TYPENAME range_const_iterator<SequenceT>::type> >();
));
detail::find_format_all_impl( detail::find_format_all_impl(
Input, Input,

View File

@ -113,8 +113,8 @@ namespace boost {
FinderT Finder ) : FinderT Finder ) :
detail::find_iterator_base<IteratorT>(Finder,0) detail::find_iterator_base<IteratorT>(Finder,0)
{ {
iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_col(::boost::as_literal(Col)); iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_col(as_literal(Col));
m_Match=::boost::make_iterator_range(::boost::begin(lit_col), ::boost::begin(lit_col)); m_Match=make_iterator_range(::boost::begin(lit_col), ::boost::begin(lit_col));
m_End=::boost::end(lit_col); m_End=::boost::end(lit_col);
increment(); increment();
@ -240,7 +240,7 @@ namespace boost {
m_Match(Other.m_Match), m_Match(Other.m_Match),
m_Next(Other.m_Next), m_Next(Other.m_Next),
m_End(Other.m_End), m_End(Other.m_End),
m_bEof(Other.m_bEof) m_bEof(false)
{} {}
//! Constructor //! Constructor
@ -259,11 +259,7 @@ namespace boost {
m_End(End), m_End(End),
m_bEof(false) m_bEof(false)
{ {
// force the correct behavior for empty sequences and yield at least one token increment();
if(Begin!=End)
{
increment();
}
} }
//! Constructor //! Constructor
/*! /*!
@ -277,16 +273,12 @@ namespace boost {
detail::find_iterator_base<IteratorT>(Finder,0), detail::find_iterator_base<IteratorT>(Finder,0),
m_bEof(false) m_bEof(false)
{ {
iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_col(::boost::as_literal(Col)); iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_col(as_literal(Col));
m_Match=make_iterator_range(::boost::begin(lit_col), ::boost::begin(lit_col)); m_Match=make_iterator_range(::boost::begin(lit_col), ::boost::begin(lit_col));
m_Next=::boost::begin(lit_col); m_Next=::boost::begin(lit_col);
m_End=::boost::end(lit_col); m_End=::boost::end(lit_col);
// force the correct behavior for empty sequences and yield at least one token increment();
if(m_Next!=m_End)
{
increment();
}
} }

View File

@ -56,7 +56,7 @@ namespace boost {
detail::first_finderF< detail::first_finderF<
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type, range_const_iterator<RangeT>::type,
is_equal>( ::boost::as_literal(Search), is_equal() ) ; is_equal>( as_literal(Search), is_equal() ) ;
} }
//! "First" finder //! "First" finder
@ -74,7 +74,7 @@ namespace boost {
detail::first_finderF< detail::first_finderF<
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type, range_const_iterator<RangeT>::type,
PredicateT>( ::boost::as_literal(Search), Comp ); PredicateT>( as_literal(Search), Comp );
} }
//! "Last" finder //! "Last" finder
@ -97,7 +97,7 @@ namespace boost {
detail::last_finderF< detail::last_finderF<
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type, range_const_iterator<RangeT>::type,
is_equal>( ::boost::as_literal(Search), is_equal() ); is_equal>( as_literal(Search), is_equal() );
} }
//! "Last" finder //! "Last" finder
/*! /*!
@ -113,7 +113,7 @@ namespace boost {
detail::last_finderF< detail::last_finderF<
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type, range_const_iterator<RangeT>::type,
PredicateT>( ::boost::as_literal(Search), Comp ) ; PredicateT>( as_literal(Search), Comp ) ;
} }
//! "Nth" finder //! "Nth" finder
@ -139,7 +139,7 @@ namespace boost {
detail::nth_finderF< detail::nth_finderF<
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type, range_const_iterator<RangeT>::type,
is_equal>( ::boost::as_literal(Search), Nth, is_equal() ) ; is_equal>( as_literal(Search), Nth, is_equal() ) ;
} }
//! "Nth" finder //! "Nth" finder
/*! /*!
@ -158,7 +158,7 @@ namespace boost {
detail::nth_finderF< detail::nth_finderF<
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type, range_const_iterator<RangeT>::type,
PredicateT>( ::boost::as_literal(Search), Nth, Comp ); PredicateT>( as_literal(Search), Nth, Comp );
} }
//! "Head" finder //! "Head" finder

View File

@ -36,7 +36,7 @@ namespace boost {
//! Constant formatter //! Constant formatter
/*! /*!
Constructs a \c const_formatter. Const formatter always returns Construct the \c const_formatter. Const formatter always returns
the same value, regardless of the parameter. the same value, regardless of the parameter.
\param Format A predefined value used as a result for formating \param Format A predefined value used as a result for formating
@ -50,12 +50,12 @@ namespace boost {
{ {
return detail::const_formatF< return detail::const_formatF<
iterator_range< iterator_range<
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >(::boost::as_literal(Format)); BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >(as_literal(Format));
} }
//! Identity formatter //! Identity formatter
/*! /*!
Constructs an \c identity_formatter. Identity formatter always returns Construct the \c identity_formatter. Identity formatter always returns
the parameter. the parameter.
\return An instance of the \c identity_formatter object. \return An instance of the \c identity_formatter object.
@ -73,7 +73,7 @@ namespace boost {
//! Empty formatter //! Empty formatter
/*! /*!
Constructs an \c empty_formatter. Empty formatter always returns an empty Construct the \c empty_formatter. Empty formatter always returns an empty
sequence. sequence.
\param Input container used to select a correct value_type for the \param Input container used to select a correct value_type for the
@ -89,22 +89,6 @@ namespace boost {
BOOST_STRING_TYPENAME range_value<RangeT>::type>(); BOOST_STRING_TYPENAME range_value<RangeT>::type>();
} }
//! Empty formatter
/*!
Constructs a \c dissect_formatter. Dissect formatter uses a specified finder
to extract a portion of the formatted sequence. The first finder's match is returned
as a result
\param Finder a finder used to select a portion of the formated sequence
\return An instance of the \c dissect_formatter object.
*/
template<typename FinderT>
inline detail::dissect_formatF< FinderT >
dissect_formatter(const FinderT& Finder)
{
return detail::dissect_formatF<FinderT>(Finder);
}
} // namespace algorithm } // namespace algorithm
@ -112,7 +96,6 @@ namespace boost {
using algorithm::const_formatter; using algorithm::const_formatter;
using algorithm::identity_formatter; using algorithm::identity_formatter;
using algorithm::empty_formatter; using algorithm::empty_formatter;
using algorithm::dissect_formatter;
} // namespace boost } // namespace boost

View File

@ -74,13 +74,11 @@ namespace boost {
RangeT& Input, RangeT& Input,
FinderT Finder ) FinderT Finder )
{ {
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept< FinderConcept<FinderT,
FinderT, BOOST_STRING_TYPENAME range_iterator<RangeT>::type> >();
BOOST_STRING_TYPENAME range_iterator<RangeT>::type>
));
iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(as_literal(Input));
typedef BOOST_STRING_TYPENAME typedef BOOST_STRING_TYPENAME
range_iterator<RangeT>::type input_iterator_type; range_iterator<RangeT>::type input_iterator_type;
@ -96,12 +94,12 @@ namespace boost {
transform_iter_type; transform_iter_type;
transform_iter_type itBegin= transform_iter_type itBegin=
::boost::make_transform_iterator( make_transform_iterator(
find_iterator_type( ::boost::begin(lit_input), InputEnd, Finder ), find_iterator_type( ::boost::begin(lit_input), InputEnd, Finder ),
copy_range_type()); copy_range_type());
transform_iter_type itEnd= transform_iter_type itEnd=
::boost::make_transform_iterator( make_transform_iterator(
find_iterator_type(), find_iterator_type(),
copy_range_type()); copy_range_type());
@ -145,12 +143,11 @@ namespace boost {
RangeT& Input, RangeT& Input,
FinderT Finder ) FinderT Finder )
{ {
BOOST_CONCEPT_ASSERT(( function_requires<
FinderConcept<FinderT, FinderConcept<FinderT,
BOOST_STRING_TYPENAME range_iterator<RangeT>::type> BOOST_STRING_TYPENAME range_iterator<RangeT>::type> >();
));
iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(as_literal(Input));
typedef BOOST_STRING_TYPENAME typedef BOOST_STRING_TYPENAME
range_iterator<RangeT>::type input_iterator_type; range_iterator<RangeT>::type input_iterator_type;
@ -166,12 +163,12 @@ namespace boost {
transform_iter_type; transform_iter_type;
transform_iter_type itBegin= transform_iter_type itBegin=
::boost::make_transform_iterator( make_transform_iterator(
find_iterator_type( ::boost::begin(lit_input), InputEnd, Finder ), find_iterator_type( ::boost::begin(lit_input), InputEnd, Finder ),
copy_range_type() ); copy_range_type() );
transform_iter_type itEnd= transform_iter_type itEnd=
::boost::make_transform_iterator( make_transform_iterator(
find_iterator_type(), find_iterator_type(),
copy_range_type() ); copy_range_type() );

View File

@ -68,7 +68,7 @@ namespace boost {
for(;itBegin!=itEnd; ++itBegin) for(;itBegin!=itEnd; ++itBegin)
{ {
// Add separator // Add separator
detail::insert(Result, ::boost::end(Result), ::boost::as_literal(Separator)); detail::insert(Result, ::boost::end(Result), as_literal(Separator));
// Add element // Add element
detail::insert(Result, ::boost::end(Result), *itBegin); detail::insert(Result, ::boost::end(Result), *itBegin);
} }
@ -123,7 +123,7 @@ namespace boost {
if(Pred(*itBegin)) if(Pred(*itBegin))
{ {
// Add separator // Add separator
detail::insert(Result, ::boost::end(Result), ::boost::as_literal(Separator)); detail::insert(Result, ::boost::end(Result), as_literal(Separator));
// Add element // Add element
detail::insert(Result, ::boost::end(Result), *itBegin); detail::insert(Result, ::boost::end(Result), *itBegin);
} }

View File

@ -59,8 +59,8 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
PredicateT Comp) PredicateT Comp)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(as_literal(Input));
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(::boost::as_literal(Test)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(as_literal(Test));
typedef BOOST_STRING_TYPENAME typedef BOOST_STRING_TYPENAME
range_const_iterator<Range1T>::type Iterator1T; range_const_iterator<Range1T>::type Iterator1T;
@ -92,7 +92,7 @@ namespace boost {
const Range1T& Input, const Range1T& Input,
const Range2T& Test) const Range2T& Test)
{ {
return ::boost::algorithm::starts_with(Input, Test, is_equal()); return starts_with(Input, Test, is_equal());
} }
//! 'Starts with' predicate ( case insensitive ) //! 'Starts with' predicate ( case insensitive )
@ -114,7 +114,7 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::starts_with(Input, Test, is_iequal(Loc)); return starts_with(Input, Test, is_iequal(Loc));
} }
@ -141,8 +141,8 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
PredicateT Comp) PredicateT Comp)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(as_literal(Input));
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(::boost::as_literal(Test)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(as_literal(Test));
typedef BOOST_STRING_TYPENAME typedef BOOST_STRING_TYPENAME
range_const_iterator<Range1T>::type Iterator1T; range_const_iterator<Range1T>::type Iterator1T;
@ -169,7 +169,7 @@ namespace boost {
const Range1T& Input, const Range1T& Input,
const Range2T& Test) const Range2T& Test)
{ {
return ::boost::algorithm::ends_with(Input, Test, is_equal()); return ends_with(Input, Test, is_equal());
} }
//! 'Ends with' predicate ( case insensitive ) //! 'Ends with' predicate ( case insensitive )
@ -191,7 +191,7 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::ends_with(Input, Test, is_iequal(Loc)); return ends_with(Input, Test, is_iequal(Loc));
} }
// contains predicate -----------------------------------------------// // contains predicate -----------------------------------------------//
@ -215,17 +215,17 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
PredicateT Comp) PredicateT Comp)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(as_literal(Input));
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(::boost::as_literal(Test)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(as_literal(Test));
if (::boost::empty(lit_test)) if (empty(lit_test))
{ {
// Empty range is contained always // Empty range is contained always
return true; return true;
} }
// Use the temporary variable to make VACPP happy // Use the temporary variable to make VACPP happy
bool bResult=(::boost::algorithm::first_finder(lit_test,Comp)(::boost::begin(lit_input), ::boost::end(lit_input))); bool bResult=(first_finder(lit_test,Comp)(::boost::begin(lit_input), ::boost::end(lit_input)));
return bResult; return bResult;
} }
@ -238,7 +238,7 @@ namespace boost {
const Range1T& Input, const Range1T& Input,
const Range2T& Test) const Range2T& Test)
{ {
return ::boost::algorithm::contains(Input, Test, is_equal()); return contains(Input, Test, is_equal());
} }
//! 'Contains' predicate ( case insensitive ) //! 'Contains' predicate ( case insensitive )
@ -259,7 +259,7 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::contains(Input, Test, is_iequal(Loc)); return contains(Input, Test, is_iequal(Loc));
} }
// equals predicate -----------------------------------------------// // equals predicate -----------------------------------------------//
@ -286,8 +286,8 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
PredicateT Comp) PredicateT Comp)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_input(as_literal(Input));
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(::boost::as_literal(Test)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_test(as_literal(Test));
typedef BOOST_STRING_TYPENAME typedef BOOST_STRING_TYPENAME
range_const_iterator<Range1T>::type Iterator1T; range_const_iterator<Range1T>::type Iterator1T;
@ -319,7 +319,7 @@ namespace boost {
const Range1T& Input, const Range1T& Input,
const Range2T& Test) const Range2T& Test)
{ {
return ::boost::algorithm::equals(Input, Test, is_equal()); return equals(Input, Test, is_equal());
} }
//! 'Equals' predicate ( case insensitive ) //! 'Equals' predicate ( case insensitive )
@ -343,7 +343,7 @@ namespace boost {
const Range2T& Test, const Range2T& Test,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::equals(Input, Test, is_iequal(Loc)); return equals(Input, Test, is_iequal(Loc));
} }
// lexicographical_compare predicate -----------------------------// // lexicographical_compare predicate -----------------------------//
@ -372,8 +372,8 @@ namespace boost {
const Range2T& Arg2, const Range2T& Arg2,
PredicateT Pred) PredicateT Pred)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_arg1(::boost::as_literal(Arg1)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range1T>::type> lit_arg1(as_literal(Arg1));
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_arg2(::boost::as_literal(Arg2)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<Range2T>::type> lit_arg2(as_literal(Arg2));
return std::lexicographical_compare( return std::lexicographical_compare(
::boost::begin(lit_arg1), ::boost::begin(lit_arg1),
@ -392,7 +392,7 @@ namespace boost {
const Range1T& Arg1, const Range1T& Arg1,
const Range2T& Arg2) const Range2T& Arg2)
{ {
return ::boost::algorithm::lexicographical_compare(Arg1, Arg2, is_less()); return lexicographical_compare(Arg1, Arg2, is_less());
} }
//! Lexicographical compare predicate (case-insensitive) //! Lexicographical compare predicate (case-insensitive)
@ -417,7 +417,7 @@ namespace boost {
const Range2T& Arg2, const Range2T& Arg2,
const std::locale& Loc=std::locale()) const std::locale& Loc=std::locale())
{ {
return ::boost::algorithm::lexicographical_compare(Arg1, Arg2, is_iless(Loc)); return lexicographical_compare(Arg1, Arg2, is_iless(Loc));
} }
@ -439,7 +439,7 @@ namespace boost {
const RangeT& Input, const RangeT& Input,
PredicateT Pred) PredicateT Pred)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_input(as_literal(Input));
typedef BOOST_STRING_TYPENAME typedef BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type Iterator1T; range_const_iterator<RangeT>::type Iterator1T;

View File

@ -60,9 +60,9 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_iterator<RangeT>::type> lit_input(as_literal(Input));
return ::boost::algorithm::regex_finder(Rx,Flags)( return regex_finder(Rx,Flags)(
::boost::begin(lit_input), ::boost::end(lit_input) ); ::boost::begin(lit_input), ::boost::end(lit_input) );
} }
@ -98,11 +98,11 @@ namespace boost {
const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format, const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,
match_flag_type Flags=match_default | format_default ) match_flag_type Flags=match_default | format_default )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::regex_formatter( Format, Flags ) ); regex_formatter( Format, Flags ) );
} }
//! Replace regex algorithm //! Replace regex algorithm
@ -120,10 +120,10 @@ namespace boost {
const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format, const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,
match_flag_type Flags=match_default | format_default ) match_flag_type Flags=match_default | format_default )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::regex_formatter( Format, Flags ) ); regex_formatter( Format, Flags ) );
} }
//! Replace regex algorithm //! Replace regex algorithm
@ -147,10 +147,10 @@ namespace boost {
const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format, const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,
match_flag_type Flags=match_default | format_default ) match_flag_type Flags=match_default | format_default )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::regex_formatter( Format, Flags ) ); regex_formatter( Format, Flags ) );
} }
// replace_all_regex --------------------------------------------------------------------// // replace_all_regex --------------------------------------------------------------------//
@ -184,11 +184,11 @@ namespace boost {
const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format, const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,
match_flag_type Flags=match_default | format_default ) match_flag_type Flags=match_default | format_default )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Output, Output,
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::regex_formatter( Format, Flags ) ); regex_formatter( Format, Flags ) );
} }
//! Replace all regex algorithm //! Replace all regex algorithm
@ -206,10 +206,10 @@ namespace boost {
const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format, const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,
match_flag_type Flags=match_default | format_default ) match_flag_type Flags=match_default | format_default )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::regex_formatter( Format, Flags ) ); regex_formatter( Format, Flags ) );
} }
//! Replace all regex algorithm //! Replace all regex algorithm
@ -233,10 +233,10 @@ namespace boost {
const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format, const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,
match_flag_type Flags=match_default | format_default ) match_flag_type Flags=match_default | format_default )
{ {
::boost::algorithm::find_format_all( find_format_all(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::regex_formatter( Format, Flags ) ); regex_formatter( Format, Flags ) );
} }
// erase_regex --------------------------------------------------------------------// // erase_regex --------------------------------------------------------------------//
@ -267,11 +267,11 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase regex algorithm //! Erase regex algorithm
@ -287,10 +287,10 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase regex algorithm //! Erase regex algorithm
@ -311,10 +311,10 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
// erase_all_regex --------------------------------------------------------------------// // erase_all_regex --------------------------------------------------------------------//
@ -346,11 +346,11 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Output, Output,
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase all regex algorithm //! Erase all regex algorithm
@ -366,10 +366,10 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
//! Erase all regex algorithm //! Erase all regex algorithm
@ -390,10 +390,10 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
::boost::algorithm::find_format_all( find_format_all(
Input, Input,
::boost::algorithm::regex_finder( Rx, Flags ), regex_finder( Rx, Flags ),
::boost::algorithm::empty_formatter( Input ) ); empty_formatter( Input ) );
} }
// find_all_regex ------------------------------------------------------------------// // find_all_regex ------------------------------------------------------------------//
@ -431,10 +431,10 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
return ::boost::algorithm::iter_find( return iter_find(
Result, Result,
Input, Input,
::boost::algorithm::regex_finder(Rx,Flags) ); regex_finder(Rx,Flags) );
} }
// split_regex ------------------------------------------------------------------// // split_regex ------------------------------------------------------------------//
@ -472,10 +472,10 @@ namespace boost {
const basic_regex<CharT, RegexTraitsT>& Rx, const basic_regex<CharT, RegexTraitsT>& Rx,
match_flag_type Flags=match_default ) match_flag_type Flags=match_default )
{ {
return ::boost::algorithm::iter_split( return iter_split(
Result, Result,
Input, Input,
::boost::algorithm::regex_finder(Rx,Flags) ); regex_finder(Rx,Flags) );
} }
// join_if ------------------------------------------------------------------// // join_if ------------------------------------------------------------------//
@ -525,7 +525,7 @@ namespace boost {
// Roll to the first element that will be added // Roll to the first element that will be added
while( while(
itBegin!=itEnd && itBegin!=itEnd &&
!::boost::regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) ++itBegin; !regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) ++itBegin;
// Add this element // Add this element
if(itBegin!=itEnd) if(itBegin!=itEnd)
@ -536,10 +536,10 @@ namespace boost {
for(;itBegin!=itEnd; ++itBegin) for(;itBegin!=itEnd; ++itBegin)
{ {
if(::boost::regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) if(regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags))
{ {
// Add separator // Add separator
detail::insert(Result, ::boost::end(Result), ::boost::as_literal(Separator)); detail::insert(Result, ::boost::end(Result), as_literal(Separator));
// Add element // Add element
detail::insert(Result, ::boost::end(Result), *itBegin); detail::insert(Result, ::boost::end(Result), *itBegin);
} }
@ -593,7 +593,7 @@ namespace boost {
// Roll to the first element that will be added // Roll to the first element that will be added
while( while(
itBegin!=itEnd && itBegin!=itEnd &&
!::boost::regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) ++itBegin; !regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) ++itBegin;
// Add this element // Add this element
if(itBegin!=itEnd) if(itBegin!=itEnd)
@ -604,10 +604,10 @@ namespace boost {
for(;itBegin!=itEnd; ++itBegin) for(;itBegin!=itEnd; ++itBegin)
{ {
if(::boost::regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) if(regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags))
{ {
// Add separator // Add separator
detail::insert(Result, ::boost::end(Result), ::boost::as_literal(Separator)); detail::insert(Result, ::boost::end(Result), as_literal(Separator));
// Add element // Add element
detail::insert(Result, ::boost::end(Result), *itBegin); detail::insert(Result, ::boost::end(Result), *itBegin);
} }

View File

@ -61,11 +61,11 @@ namespace boost {
range_const_iterator<Range1T>::type>& SearchRange, range_const_iterator<Range1T>::type>& SearchRange,
const Range2T& Format) const Range2T& Format)
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::range_finder(SearchRange), range_finder(SearchRange),
::boost::algorithm::const_formatter(Format)); const_formatter(Format));
} }
//! Replace range algorithm //! Replace range algorithm
@ -80,10 +80,10 @@ namespace boost {
range_const_iterator<SequenceT>::type>& SearchRange, range_const_iterator<SequenceT>::type>& SearchRange,
const RangeT& Format) const RangeT& Format)
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::range_finder(SearchRange), range_finder(SearchRange),
::boost::algorithm::const_formatter(Format)); const_formatter(Format));
} }
//! Replace range algorithm //! Replace range algorithm
@ -103,10 +103,10 @@ namespace boost {
range_iterator<SequenceT>::type>& SearchRange, range_iterator<SequenceT>::type>& SearchRange,
const RangeT& Format) const RangeT& Format)
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::range_finder(SearchRange), range_finder(SearchRange),
::boost::algorithm::const_formatter(Format)); const_formatter(Format));
} }
// replace_first --------------------------------------------------------------------// // replace_first --------------------------------------------------------------------//
@ -138,11 +138,11 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const Range3T& Format) const Range3T& Format)
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace first algorithm //! Replace first algorithm
@ -155,10 +155,10 @@ namespace boost {
const Range1T& Search, const Range1T& Search,
const Range2T& Format ) const Range2T& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace first algorithm //! Replace first algorithm
@ -176,10 +176,10 @@ namespace boost {
const Range1T& Search, const Range1T& Search,
const Range2T& Format ) const Range2T& Format )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_first ( case insensitive ) ---------------------------------------------// // replace_first ( case insensitive ) ---------------------------------------------//
@ -214,11 +214,11 @@ namespace boost {
const Range3T& Format, const Range3T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace first algorithm ( case insensitive ) //! Replace first algorithm ( case insensitive )
@ -232,10 +232,10 @@ namespace boost {
const Range1T& Format, const Range1T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace first algorithm ( case insensitive ) //! Replace first algorithm ( case insensitive )
@ -256,10 +256,10 @@ namespace boost {
const Range2T& Format, const Range2T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_last --------------------------------------------------------------------// // replace_last --------------------------------------------------------------------//
@ -291,11 +291,11 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const Range3T& Format ) const Range3T& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::last_finder(Search), last_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace last algorithm //! Replace last algorithm
@ -308,10 +308,10 @@ namespace boost {
const Range1T& Search, const Range1T& Search,
const Range2T& Format ) const Range2T& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::last_finder(Search), last_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace last algorithm //! Replace last algorithm
@ -329,10 +329,10 @@ namespace boost {
const Range1T& Search, const Range1T& Search,
const Range2T& Format ) const Range2T& Format )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::last_finder(Search), last_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_last ( case insensitive ) -----------------------------------------------// // replace_last ( case insensitive ) -----------------------------------------------//
@ -367,11 +367,11 @@ namespace boost {
const Range3T& Format, const Range3T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::last_finder(Search, is_iequal(Loc)), last_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace last algorithm ( case insensitive ) //! Replace last algorithm ( case insensitive )
@ -385,10 +385,10 @@ namespace boost {
const Range2T& Format, const Range2T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::last_finder(Search, is_iequal(Loc)), last_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace last algorithm ( case insensitive ) //! Replace last algorithm ( case insensitive )
@ -410,10 +410,10 @@ namespace boost {
const Range2T& Format, const Range2T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::last_finder(Search, is_iequal(Loc)), last_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_nth --------------------------------------------------------------------// // replace_nth --------------------------------------------------------------------//
@ -448,11 +448,11 @@ namespace boost {
int Nth, int Nth,
const Range3T& Format ) const Range3T& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::nth_finder(Search, Nth), nth_finder(Search, Nth),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace nth algorithm //! Replace nth algorithm
@ -466,10 +466,10 @@ namespace boost {
int Nth, int Nth,
const Range2T& Format ) const Range2T& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth), nth_finder(Search, Nth),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace nth algorithm //! Replace nth algorithm
@ -490,10 +490,10 @@ namespace boost {
int Nth, int Nth,
const Range2T& Format ) const Range2T& Format )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth), nth_finder(Search, Nth),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_nth ( case insensitive ) -----------------------------------------------// // replace_nth ( case insensitive ) -----------------------------------------------//
@ -531,11 +531,11 @@ namespace boost {
const Range3T& Format, const Range3T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::nth_finder(Search, Nth, is_iequal(Loc) ), nth_finder(Search, Nth, is_iequal(Loc) ),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace nth algorithm ( case insensitive ) //! Replace nth algorithm ( case insensitive )
@ -550,10 +550,10 @@ namespace boost {
const Range2T& Format, const Range2T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth, is_iequal(Loc)), nth_finder(Search, Nth, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace nth algorithm ( case insensitive ) //! Replace nth algorithm ( case insensitive )
@ -577,10 +577,10 @@ namespace boost {
const Range2T& Format, const Range2T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::nth_finder(Search, Nth, is_iequal(Loc)), nth_finder(Search, Nth, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_all --------------------------------------------------------------------// // replace_all --------------------------------------------------------------------//
@ -612,11 +612,11 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const Range3T& Format ) const Range3T& Format )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace all algorithm //! Replace all algorithm
@ -629,10 +629,10 @@ namespace boost {
const Range1T& Search, const Range1T& Search,
const Range2T& Format ) const Range2T& Format )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace all algorithm //! Replace all algorithm
@ -651,10 +651,10 @@ namespace boost {
const Range1T& Search, const Range1T& Search,
const Range2T& Format ) const Range2T& Format )
{ {
::boost::algorithm::find_format_all( find_format_all(
Input, Input,
::boost::algorithm::first_finder(Search), first_finder(Search),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_all ( case insensitive ) -----------------------------------------------// // replace_all ( case insensitive ) -----------------------------------------------//
@ -689,11 +689,11 @@ namespace boost {
const Range3T& Format, const Range3T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Output, Output,
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace all algorithm ( case insensitive ) //! Replace all algorithm ( case insensitive )
@ -707,10 +707,10 @@ namespace boost {
const Range2T& Format, const Range2T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::find_format_all_copy( return find_format_all_copy(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace all algorithm ( case insensitive ) //! Replace all algorithm ( case insensitive )
@ -731,10 +731,10 @@ namespace boost {
const Range2T& Format, const Range2T& Format,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
::boost::algorithm::find_format_all( find_format_all(
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc)), first_finder(Search, is_iequal(Loc)),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_head --------------------------------------------------------------------// // replace_head --------------------------------------------------------------------//
@ -769,11 +769,11 @@ namespace boost {
int N, int N,
const Range2T& Format ) const Range2T& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::head_finder(N), head_finder(N),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace head algorithm //! Replace head algorithm
@ -786,10 +786,10 @@ namespace boost {
int N, int N,
const RangeT& Format ) const RangeT& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::head_finder(N), head_finder(N),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace head algorithm //! Replace head algorithm
@ -811,10 +811,10 @@ namespace boost {
int N, int N,
const RangeT& Format ) const RangeT& Format )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::head_finder(N), head_finder(N),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
// replace_tail --------------------------------------------------------------------// // replace_tail --------------------------------------------------------------------//
@ -849,11 +849,11 @@ namespace boost {
int N, int N,
const Range2T& Format ) const Range2T& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Output, Output,
Input, Input,
::boost::algorithm::tail_finder(N), tail_finder(N),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace tail algorithm //! Replace tail algorithm
@ -866,10 +866,10 @@ namespace boost {
int N, int N,
const RangeT& Format ) const RangeT& Format )
{ {
return ::boost::algorithm::find_format_copy( return find_format_copy(
Input, Input,
::boost::algorithm::tail_finder(N), tail_finder(N),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
//! Replace tail algorithm //! Replace tail algorithm
@ -891,10 +891,10 @@ namespace boost {
int N, int N,
const RangeT& Format ) const RangeT& Format )
{ {
::boost::algorithm::find_format( find_format(
Input, Input,
::boost::algorithm::tail_finder(N), tail_finder(N),
::boost::algorithm::const_formatter(Format) ); const_formatter(Format) );
} }
} // namespace algorithm } // namespace algorithm

View File

@ -64,10 +64,10 @@ namespace boost {
Range1T& Input, Range1T& Input,
const Range2T& Search) const Range2T& Search)
{ {
return ::boost::algorithm::iter_find( return iter_find(
Result, Result,
Input, Input,
::boost::algorithm::first_finder(Search) ); first_finder(Search) );
} }
//! Find all algorithm ( case insensitive ) //! Find all algorithm ( case insensitive )
@ -100,10 +100,10 @@ namespace boost {
const Range2T& Search, const Range2T& Search,
const std::locale& Loc=std::locale() ) const std::locale& Loc=std::locale() )
{ {
return ::boost::algorithm::iter_find( return iter_find(
Result, Result,
Input, Input,
::boost::algorithm::first_finder(Search, is_iequal(Loc) ) ); first_finder(Search, is_iequal(Loc) ) );
} }
@ -143,10 +143,10 @@ namespace boost {
PredicateT Pred, PredicateT Pred,
token_compress_mode_type eCompress=token_compress_off ) token_compress_mode_type eCompress=token_compress_off )
{ {
return ::boost::algorithm::iter_split( return iter_split(
Result, Result,
Input, Input,
::boost::algorithm::token_finder( Pred, eCompress ) ); token_finder( Pred, eCompress ) );
} }
} // namespace algorithm } // namespace algorithm

View File

@ -63,7 +63,7 @@ namespace boost {
const RangeT& Input, const RangeT& Input,
PredicateT IsSpace) PredicateT IsSpace)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_range(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_range(as_literal(Input));
std::copy( std::copy(
::boost::algorithm::detail::trim_begin( ::boost::algorithm::detail::trim_begin(
@ -106,7 +106,7 @@ namespace boost {
inline SequenceT trim_left_copy(const SequenceT& Input, const std::locale& Loc=std::locale()) inline SequenceT trim_left_copy(const SequenceT& Input, const std::locale& Loc=std::locale())
{ {
return return
::boost::algorithm::trim_left_copy_if( trim_left_copy_if(
Input, Input,
is_space(Loc)); is_space(Loc));
} }
@ -142,7 +142,7 @@ namespace boost {
template<typename SequenceT> template<typename SequenceT>
inline void trim_left(SequenceT& Input, const std::locale& Loc=std::locale()) inline void trim_left(SequenceT& Input, const std::locale& Loc=std::locale())
{ {
::boost::algorithm::trim_left_if( trim_left_if(
Input, Input,
is_space(Loc)); is_space(Loc));
} }
@ -171,7 +171,7 @@ namespace boost {
const RangeT& Input, const RangeT& Input,
PredicateT IsSpace ) PredicateT IsSpace )
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_range(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_range(as_literal(Input));
std::copy( std::copy(
::boost::begin(lit_range), ::boost::begin(lit_range),
@ -215,7 +215,7 @@ namespace boost {
inline SequenceT trim_right_copy(const SequenceT& Input, const std::locale& Loc=std::locale()) inline SequenceT trim_right_copy(const SequenceT& Input, const std::locale& Loc=std::locale())
{ {
return return
::boost::algorithm::trim_right_copy_if( trim_right_copy_if(
Input, Input,
is_space(Loc)); is_space(Loc));
} }
@ -254,7 +254,7 @@ namespace boost {
template<typename SequenceT> template<typename SequenceT>
inline void trim_right(SequenceT& Input, const std::locale& Loc=std::locale()) inline void trim_right(SequenceT& Input, const std::locale& Loc=std::locale())
{ {
::boost::algorithm::trim_right_if( trim_right_if(
Input, Input,
is_space(Loc) ); is_space(Loc) );
} }
@ -283,7 +283,7 @@ namespace boost {
const RangeT& Input, const RangeT& Input,
PredicateT IsSpace) PredicateT IsSpace)
{ {
iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_range(::boost::as_literal(Input)); iterator_range<BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> lit_range(as_literal(Input));
BOOST_STRING_TYPENAME BOOST_STRING_TYPENAME
range_const_iterator<RangeT>::type TrimEnd= range_const_iterator<RangeT>::type TrimEnd=
@ -340,7 +340,7 @@ namespace boost {
inline SequenceT trim_copy( const SequenceT& Input, const std::locale& Loc=std::locale() ) inline SequenceT trim_copy( const SequenceT& Input, const std::locale& Loc=std::locale() )
{ {
return return
::boost::algorithm::trim_copy_if( trim_copy_if(
Input, Input,
is_space(Loc) ); is_space(Loc) );
} }
@ -357,8 +357,8 @@ namespace boost {
template<typename SequenceT, typename PredicateT> template<typename SequenceT, typename PredicateT>
inline void trim_if(SequenceT& Input, PredicateT IsSpace) inline void trim_if(SequenceT& Input, PredicateT IsSpace)
{ {
::boost::algorithm::trim_right_if( Input, IsSpace ); trim_right_if( Input, IsSpace );
::boost::algorithm::trim_left_if( Input, IsSpace ); trim_left_if( Input, IsSpace );
} }
//! Trim //! Trim
@ -372,7 +372,7 @@ namespace boost {
template<typename SequenceT> template<typename SequenceT>
inline void trim(SequenceT& Input, const std::locale& Loc=std::locale()) inline void trim(SequenceT& Input, const std::locale& Loc=std::locale())
{ {
::boost::algorithm::trim_if( trim_if(
Input, Input,
is_space( Loc ) ); is_space( Loc ) );
} }

View File

@ -1,127 +0,0 @@
// Boost string_algo library trim.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_TRIM_ALL_HPP
#define BOOST_STRING_TRIM_ALL_HPP
#include <boost/algorithm/string/config.hpp>
#include <boost/algorithm/string/trim.hpp>
#include <boost/algorithm/string/classification.hpp>
#include <boost/algorithm/string/find_format.hpp>
#include <boost/algorithm/string/formatter.hpp>
#include <boost/algorithm/string/finder.hpp>
#include <locale>
/*! \file
Defines trim_all algorithms.
Just like \c trim, \c trim_all removes all trailing and leading spaces from a
sequence (string). In addition, spaces in the middle of the sequence are truncated
to just one character. Space is recognized using given locales.
Parametric (\c _if) variants use a predicate (functor) to select which characters
are to be trimmed..
Functions take a selection predicate as a parameter, which is used to determine
whether a character is a space. Common predicates are provided in classification.hpp header.
*/
namespace boost {
namespace algorithm {
// multi line trim ----------------------------------------------- //
//! Trim All - parametric
/*!
Remove all leading and trailing spaces from the input and
compress all other spaces to a single space.
The result is a trimmed copy of the input
\param Input An input sequence
\param IsSpace An unary predicate identifying spaces
\return A trimmed copy of the input
*/
template<typename SequenceT, typename PredicateT>
inline SequenceT trim_all_copy_if(const SequenceT& Input, PredicateT IsSpace)
{
return
::boost::find_format_all_copy(
::boost::trim_copy_if(Input, IsSpace),
::boost::token_finder(IsSpace, ::boost::token_compress_on),
::boost::dissect_formatter(::boost::head_finder(1)));
}
//! Trim All
/*!
Remove all leading and trailing spaces from the input and
compress all other spaces to a single space.
The input sequence is modified in-place.
\param Input An input sequence
\param IsSpace An unary predicate identifying spaces
*/
template<typename SequenceT, typename PredicateT>
inline void trim_all_if(SequenceT& Input, PredicateT IsSpace)
{
::boost::trim_if(Input, IsSpace);
::boost::find_format_all(
Input,
::boost::token_finder(IsSpace, ::boost::token_compress_on),
::boost::dissect_formatter(::boost::head_finder(1)));
}
//! Trim All
/*!
Remove all leading and trailing spaces from the input and
compress all other spaces to a single space.
The result is a trimmed copy of the input
\param Input An input sequence
\param Loc A locale used for 'space' classification
\return A trimmed copy of the input
*/
template<typename SequenceT>
inline SequenceT trim_all_copy(const SequenceT& Input, const std::locale& Loc =std::locale())
{
return trim_all_copy_if(Input, ::boost::is_space(Loc));
}
//! Trim All
/*!
Remove all leading and trailing spaces from the input and
compress all other spaces to a single space.
The input sequence is modified in-place.
\param Input An input sequence
\param Loc A locale used for 'space' classification
\return A trimmed copy of the input
*/
template<typename SequenceT>
inline void trim_all(SequenceT& Input, const std::locale& Loc =std::locale())
{
trim_all_if(Input, ::boost::is_space(Loc));
}
} // namespace algorithm
// pull names to the boost namespace
using algorithm::trim_all;
using algorithm::trim_all_if;
using algorithm::trim_all_copy;
using algorithm::trim_all_copy_if;
} // namespace boost
#endif // BOOST_STRING_TRIM_ALL_HPP

View File

@ -56,7 +56,7 @@ be enough. The present library solves both problems.</p>
<tt>minmax</tt> <tt>minmax</tt>
as straightforward extensions of the C++ as straightforward extensions of the C++
standard. As it returns a pair of <tt>const&amp;</tt>, we must use the <a standard. As it returns a pair of <tt>const&amp;</tt>, we must use the <a
href="../../tuple/index.html">Boost.tuple</a> library to construct such href=:../../../../tuple/index.html>Boost.tuple</a> library to construct such
pairs. (Please note: the intent is not to fix the known defaults of pairs. (Please note: the intent is not to fix the known defaults of
<tt>std::min</tt> <tt>std::min</tt>
and <tt>std::max</tt>, but to add one more algorithms that combines both; see the and <tt>std::max</tt>, but to add one more algorithms that combines both; see the
@ -92,11 +92,11 @@ Synopsis of <tt>&lt;boost/algorithm/minmax.hpp></tt></h3>
namespace boost { namespace boost {
template &lt;class T> template &lt;class T>
tuple&lt;T const&amp;, T const&amp;> tuple&lt;T const&amp;, T const&amp;> >
minmax(const T&amp; a, const T&amp; b); minmax(const T&amp; a, const T&amp; b);
template &lt;class T, class <a href="http://www.sgi.com/tech/stl/BinaryPredicate.html">BinaryPredicate</a>> template &lt;class T, class <a href="http://www.sgi.com/tech/stl/BinaryPredicate.html">BinaryPredicate</a>>
tuple&lt;T const&amp;, T const&amp;> tuple&lt;T const&amp;, T const&amp;> >
minmax(const T&amp; a, const T&amp; b, BinaryPredicate comp); minmax(const T&amp; a, const T&amp; b, BinaryPredicate comp);
} }
@ -158,9 +158,9 @@ identical to
that they return the last instance of the largest element (and not the that they return the last instance of the largest element (and not the
first, as <tt>first_min_element</tt> and <tt>last_max_element</tt> would). first, as <tt>first_min_element</tt> and <tt>last_max_element</tt> would).
<p>The family of algorithms comprising <tt>first_min_first_max_element</tt>, <p>The family of algorithms comprising <tt>first_min_first_max_element</tt>,
<tt>first_min_last_max_element</tt>, <tt>first_min_first_max_element</tt>,
<tt>last_min_first_max_element</tt>, <tt>first_min_first_max_element</tt>,
and <tt>last_min_last_max_element</tt> can be described generically as and <tt>first_min_first_max_element</tt> can be described generically as
follows (using <i><tt>which</tt></i> and follows (using <i><tt>which</tt></i> and
<i><tt>what</tt></i> for <tt>first</tt> <i><tt>what</tt></i> for <tt>first</tt>
or <tt>last</tt>): <tt><i>which</i>_min_<i>what</i>_max_element</tt> finds or <tt>last</tt>): <tt><i>which</i>_min_<i>what</i>_max_element</tt> finds
@ -243,7 +243,7 @@ range
<a name="complexity"> <a name="complexity">
<h3> <h3>
Complexity</h3> <a NAME="Complexity"></a>Complexity</h3>
Minmax performs a single comparison and is otherwise of constant complexity. Minmax performs a single comparison and is otherwise of constant complexity.
The use of <tt>boost::tuple&lt;T const&amp;></tt> prevents copy The use of <tt>boost::tuple&lt;T const&amp;></tt> prevents copy
constructors in case the arguments are passed by reference. constructors in case the arguments are passed by reference.
@ -338,7 +338,7 @@ most</i> instead of <i>exactly</i> in the odd case.
<b>Rationale:</b></h3> <b>Rationale:</b></h3>
<a name="two_headers"> <a name="two_headers">
<h4><b>Why not a single header <tt>&lt;boost/algorithm/minmax.hpp></tt>?</b></h4> <h4><b>Why not a single header <tt>&amp;boost/algorithm/minmax.hpp></tt>?</b></h4>
<p>This was the design originally proposed and approved in the formal <p>This was the design originally proposed and approved in the formal
review. As the need for Boost.tuple became clear (due to the limitations review. As the need for Boost.tuple became clear (due to the limitations
of <tt>std::pair</tt>), it became also annoying to require another of <tt>std::pair</tt>), it became also annoying to require another
@ -438,7 +438,7 @@ comparisons).</p>
slower than slower than
<tt>first_min_element</tt> alone, still much less than <tt>first_min_element</tt> <tt>first_min_element</tt> alone, still much less than <tt>first_min_element</tt>
and and
<tt>last_max_element</tt> called separately. <a href="#Note2">[2]</a> <tt>last_max_element</tt> called separately. <a href="#Performance">[2]</a>
<h4><b>Why algorithms and not accumulators?</b></h4> <h4><b>Why algorithms and not accumulators?</b></h4>
<p>The minmax algorithms are useful in computing the extent of a range. <p>The minmax algorithms are useful in computing the extent of a range.

View File

@ -54,23 +54,23 @@ void test(BOOST_EXPLICIT_TEMPLATE_TYPE(Value))
less_count<Value> lc(counter); less_count<Value> lc(counter);
// Test functionality // Test functionality
tuple<Value const&, Value const&> result1 = boost::minmax(zero, one); tuple<Value const&, Value const&> result1 = minmax(zero, one);
BOOST_CHECK_EQUAL( get<0>(result1), zero ); BOOST_CHECK_EQUAL( get<0>(result1), zero );
BOOST_CHECK_EQUAL( get<1>(result1), one ); BOOST_CHECK_EQUAL( get<1>(result1), one );
tuple<Value const&, Value const&> result2 = boost::minmax(one, zero); tuple<Value const&, Value const&> result2 = minmax(one, zero);
BOOST_CHECK_EQUAL( get<0>(result2), zero ); BOOST_CHECK_EQUAL( get<0>(result2), zero );
BOOST_CHECK_EQUAL( get<1>(result2), one ); BOOST_CHECK_EQUAL( get<1>(result2), one );
// Test functionality and number of comparisons // Test functionality and number of comparisons
lc.reset(); lc.reset();
tuple<Value const&, Value const&> result3 = boost::minmax(zero, one, lc ); tuple<Value const&, Value const&> result3 = minmax(zero, one, lc );
BOOST_CHECK_EQUAL( get<0>(result3), zero ); BOOST_CHECK_EQUAL( get<0>(result3), zero );
BOOST_CHECK_EQUAL( get<1>(result3), one ); BOOST_CHECK_EQUAL( get<1>(result3), one );
BOOST_CHECK_EQUAL( counter, 1 ); BOOST_CHECK_EQUAL( counter, 1 );
lc.reset(); lc.reset();
tuple<Value const&, Value const&> result4 = boost::minmax(one, zero, lc ); tuple<Value const&, Value const&> result4 = minmax(one, zero, lc );
BOOST_CHECK_EQUAL( get<0>(result4), zero ); BOOST_CHECK_EQUAL( get<0>(result4), zero );
BOOST_CHECK_EQUAL( get<1>(result4), one ); BOOST_CHECK_EQUAL( get<1>(result4), one );
BOOST_CHECK_EQUAL( counter, 1); BOOST_CHECK_EQUAL( counter, 1);

View File

@ -10,11 +10,7 @@
import toolset ; import toolset ;
toolset.using doxygen ; toolset.using doxygen ;
boostbook string_algo : string_algo.xml autodoc boostbook string_algo : string_algo.xml autodoc ;
:
<xsl:param>boost.root=../../../../..
<format>pdf:<xsl:param>boost.url.prefix=http://www.boost.org/doc/libs/release/doc/html
;
doxygen autodoc doxygen autodoc
: :
@ -43,7 +39,6 @@ doxygen autodoc
[ glob ../../../../boost/algorithm/string/formatter.hpp ] [ glob ../../../../boost/algorithm/string/formatter.hpp ]
[ glob ../../../../boost/algorithm/string/regex.hpp ] [ glob ../../../../boost/algorithm/string/regex.hpp ]
[ glob ../../../../boost/algorithm/string/regex_find_format.hpp ] [ glob ../../../../boost/algorithm/string/regex_find_format.hpp ]
[ glob ../../../../boost/algorithm/string/trim_all.hpp ]
: :
<doxygen:param>HIDE_UNDOC_MEMBERS=YES <doxygen:param>HIDE_UNDOC_MEMBERS=YES
<doxygen:param>EXTRACT_PRIVATE=NO <doxygen:param>EXTRACT_PRIVATE=NO

View File

@ -25,7 +25,7 @@
</para> </para>
<para> <para>
<emphasis role="bold">Definition:</emphasis> A string is a <emphasis role="bold">Definition:</emphasis> A string is a
<ulink url="../../libs/range/index.html">range</ulink> of characters accessible in sequential <ulink url="../../libs/range/doc/range.html">range</ulink> of characters accessible in sequential
ordered fashion. Character is any value type with "cheap" copying and assignment. ordered fashion. Character is any value type with "cheap" copying and assignment.
</para> </para>
<para> <para>

View File

@ -32,9 +32,7 @@
free-standing functions and type-generators exists:</p><code>void foo( const T&, int ); <br> free-standing functions and type-generators exists:</p><code>void foo( const T&, int ); <br>
int bar( T& ); <br> int bar( T& ); <br>
foo_type_of< T >::type;</code> <br> <br><hr size="1" ><h3 >Literature</h3><ul ><li > <a href="http://www.boost.org/more/generic_programming.html#type_generator" target="_self" >Type Generators</a> </li><li > <a href="http://www.boost.org/more/generic_programming.html#concept" target="_self" >Concepts</a> </li><li > <a href="http://www.sgi.com/tech/stl/stl_introduction.html" target="_self" >Concepts and SGI STL</a> </li></ul><hr size="1" ><p >&copy; Thorsten Ottosen 2003-2004 (nesotto_AT_cs.auc.dk). foo_type_of< T >::type;</code> <br> <br><hr size="1" ><h3 >Literature</h3><ul ><li > <a href="http://www.boost.org/more/generic_programming.html#type_generator" target="_self" >Type Generators</a> </li><li > <a href="http://www.boost.org/more/generic_programming.html#concept" target="_self" >Concepts</a> </li><li > <a href="http://www.sgi.com/tech/stl/stl_introduction.html" target="_self" >Concepts and SGI STL</a> </li></ul><hr size="1" ><p >&copy; Thorsten Ottosen 2003-2004 (nesotto_AT_cs.auc.dk).
<br>Use, modification and distribution is subject to the Boost Permission to copy, use, modify, sell and distribute this software is granted provided this copyright notice appears
Software License, Version 1.0. (See accompanying file in all copies. This software is provided "as is" without express or implied warranty, and with no
<code class="filename">LICENSE_1_0.txt</code> or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>) claim as to its suitability for any purpose.</p><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></body></html>
</br> <!-- Copyright Dezide Aps 2003-2004 -->
</p>
<!-- Copyright Dezide Aps 2003-2004 -->

View File

@ -33,7 +33,7 @@
<librarypurpose> <librarypurpose>
A set of generic string-related algorithms and utilities A set of generic string-related algorithms and utilities
</librarypurpose> </librarypurpose>
<librarycategory name="category:algorithms"/> <librarycategory name="category:algoritms"/>
<librarycategory name="category:string-text"/> <librarycategory name="category:string-text"/>
</libraryinfo> </libraryinfo>

View File

@ -57,7 +57,7 @@
The magic of <ulink url="../../libs/range/index.html">Boost.Range</ulink> The magic of <ulink url="../../libs/range/index.html">Boost.Range</ulink>
provides a uniform way of handling different string types. provides a uniform way of handling different string types.
If there is a need to pass a pair of iterators, If there is a need to pass a pair of iterators,
<ulink url="../../libs/range/doc/html/range/reference/utilities/iterator_range.html"><code>boost::iterator_range</code></ulink> <ulink url="../../libs/range/doc/utility_class.html"><code>boost::iterator_range</code></ulink>
can be used to package iterators into a structure with a compatible interface. can be used to package iterators into a structure with a compatible interface.
</para> </para>
</listitem> </listitem>
@ -130,7 +130,7 @@
string str1("command.com"); string str1("command.com");
cout cout
&lt;&lt; str1 &lt;&lt; str1
&lt;&lt; (is_executable("command.com")? "is": "is not") &lt;&lt; is_executable("command.com")? "is": "is not"
&lt;&lt; "an executable" &lt;&lt; "an executable"
&lt;&lt; endl; // prints "command.com is an executable" &lt;&lt; endl; // prints "command.com is an executable"
@ -138,7 +138,7 @@
char text1[]="hello world!"; char text1[]="hello world!";
cout cout
&lt;&lt; text1 &lt;&lt; text1
&lt;&lt; (all( text1, is_lower() )? "is": "is not") &lt;&lt; all( text1, is_lower() )? "is": "is not"
&lt;&lt; " written in the lower case" &lt;&lt; " written in the lower case"
&lt;&lt; endl; // prints "hello world! is written in the lower case" &lt;&lt; endl; // prints "hello world! is written in the lower case"
</programlisting> </programlisting>
@ -169,7 +169,7 @@
<programlisting> <programlisting>
string str1=" hello world! "; string str1=" hello world! ";
string str2=trim_left_copy(str1); // str2 == "hello world! " string str2=trim_left_copy(str1); // str2 == "hello world! "
string str3=trim_right_copy(str1); // str3 == " hello world!" string str3=trim_right_copy(str2); // str3 == " hello world!"
trim(str1); // str1 == "hello world!" trim(str1); // str1 == "hello world!"
string phone="00423333444"; string phone="00423333444";
@ -208,7 +208,7 @@
</programlisting> </programlisting>
<para> <para>
We have used <functionname>find_last()</functionname> to search the <code>text</code> for "ll". We have used <functionname>find_last()</functionname> to search the <code>text</code> for "ll".
The result is given in the <ulink url="../../libs/range/doc/html/range/reference/utilities/iterator_range.html"><code>boost::iterator_range</code></ulink>. The result is given in the <ulink url="../../libs/range/doc/utility_class.html"><code>boost::iterator_range</code></ulink>.
This range delimits the This range delimits the
part of the input which satisfies the find criteria. In our example it is the last occurrence of "ll". part of the input which satisfies the find criteria. In our example it is the last occurrence of "ll".
@ -217,7 +217,7 @@
<ulink url="../../libs/range/index.html">Boost.Range</ulink>. <ulink url="../../libs/range/index.html">Boost.Range</ulink>.
The following lines transform the result. Notice that The following lines transform the result. Notice that
<ulink url="../../libs/range/doc/html/range/reference/utilities/iterator_range.html"><code>boost::iterator_range</code></ulink> has familiar <ulink url="../../libs/range/doc/utility_class.html"><code>boost::iterator_range</code></ulink> has familiar
<code>begin()</code> and <code>end()</code> methods, so it can be used like any other STL container. <code>begin()</code> and <code>end()</code> methods, so it can be used like any other STL container.
Also it is convertible to bool therefore it is easy to use find algorithms for a simple containment checking. Also it is convertible to bool therefore it is easy to use find algorithms for a simple containment checking.
</para> </para>
@ -264,7 +264,7 @@
the find iterator allows us to iterate over the substrings matching the specified criteria. the find iterator allows us to iterate over the substrings matching the specified criteria.
This facility is using the <link linkend="string_algo.finder_concept">Finder</link> to incrementally This facility is using the <link linkend="string_algo.finder_concept">Finder</link> to incrementally
search the string. search the string.
Dereferencing a find iterator yields an <ulink url="../../libs/range/doc/html/range/reference/utilities/iterator_range.html"><code>boost::iterator_range</code></ulink> Dereferencing a find iterator yields an <ulink url="../../libs/range/doc/utility_class.html"><code>boost::iterator_range</code></ulink>
object, that delimits the current match. object, that delimits the current match.
</para> </para>
<para> <para>
@ -339,7 +339,7 @@
typedef vector&lt; string &gt; split_vector_type; typedef vector&lt; string &gt; split_vector_type;
split_vector_type SplitVec; // #2: Search for tokens split_vector_type SplitVec; // #2: Search for tokens
split( SplitVec, str1, is_any_of("-*"), token_compress_on ); // SplitVec == { "hello abc","ABC","aBc goodbye" } split( SplitVec, str1, is_any_of("-*") ); // SplitVec == { "hello abc","ABC","aBc goodbye" }
</programlisting> </programlisting>
<para> <para>
<code>[hello]</code> designates an <code>iterator_range</code> delimiting this substring. <code>[hello]</code> designates an <code>iterator_range</code> delimiting this substring.

View File

@ -59,11 +59,5 @@ test-suite algorithm/string
: :
: regex : regex
] ]
[ run
find_format_test.cpp
: :
:
: find_format
]
; ;

View File

@ -1,163 +0,0 @@
// Boost string_algo library find_format_test.cpp file ------------------//
// Copyright (c) 2009 Steven Watanabe
// 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.
#include <boost/algorithm/string/find_format.hpp>
#include <boost/algorithm/string/finder.hpp>
#include <boost/algorithm/string/formatter.hpp>
// Include unit test framework
#include <boost/test/included/test_exec_monitor.hpp>
#include <boost/test/test_tools.hpp>
// We're only using const_formatter.
template<class Formatter>
struct formatter_result {
typedef boost::iterator_range<const char*> type;
};
template<class Formatter>
struct checked_formatter {
public:
checked_formatter(const Formatter& formatter) : formatter_(formatter) {}
template< typename T >
typename formatter_result<Formatter>::type operator()( const T & s ) const {
BOOST_CHECK( !s.empty() );
return formatter_(s);
}
private:
Formatter formatter_;
};
template<class Formatter>
checked_formatter<Formatter>
make_checked_formatter(const Formatter& formatter) {
return checked_formatter<Formatter>(formatter);
}
void find_format_test()
{
const std::string source = "$replace $replace";
std::string expected = "ok $replace";
std::string output(80, '\0');
std::string::iterator pos =
boost::find_format_copy(
output.begin(),
source,
boost::first_finder("$replace"),
make_checked_formatter(boost::const_formatter("ok")));
BOOST_CHECK(pos == output.begin() + expected.size());
output.erase(std::remove(output.begin(), output.end(), '\0'), output.end());
BOOST_CHECK_EQUAL(output, expected);
output =
boost::find_format_copy(
source,
boost::first_finder("$replace"),
make_checked_formatter(boost::const_formatter("ok")));
BOOST_CHECK_EQUAL(output, expected);
// now try finding a string that doesn't exist
output.resize(80);
pos =
boost::find_format_copy(
output.begin(),
source,
boost::first_finder("$noreplace"),
make_checked_formatter(boost::const_formatter("bad")));
BOOST_CHECK(pos == output.begin() + source.size());
output.erase(std::remove(output.begin(), output.end(), '\0'), output.end());
BOOST_CHECK_EQUAL(output, source);
output =
boost::find_format_copy(
source,
boost::first_finder("$noreplace"),
make_checked_formatter(boost::const_formatter("bad")));
BOOST_CHECK_EQUAL(output, source);
// in place version
output = source;
boost::find_format(
output,
boost::first_finder("$replace"),
make_checked_formatter(boost::const_formatter("ok")));
BOOST_CHECK_EQUAL(output, expected);
output = source;
boost::find_format(
output,
boost::first_finder("$noreplace"),
make_checked_formatter(boost::const_formatter("bad")));
BOOST_CHECK_EQUAL(output, source);
}
void find_format_all_test()
{
const std::string source = "$replace $replace";
std::string expected = "ok ok";
std::string output(80, '\0');
std::string::iterator pos =
boost::find_format_all_copy(output.begin(),
source,
boost::first_finder("$replace"),
boost::const_formatter("ok"));
BOOST_CHECK(pos == output.begin() + expected.size());
output.erase(std::remove(output.begin(), output.end(), '\0'), output.end());
BOOST_CHECK_EQUAL(output, expected);
output =
boost::find_format_all_copy(
source,
boost::first_finder("$replace"),
make_checked_formatter(boost::const_formatter("ok")));
BOOST_CHECK_EQUAL(output, expected);
// now try finding a string that doesn't exist
output.resize(80);
pos =
boost::find_format_all_copy(
output.begin(),
source,
boost::first_finder("$noreplace"),
make_checked_formatter(boost::const_formatter("bad")));
BOOST_CHECK(pos == output.begin() + source.size());
output.erase(std::remove(output.begin(), output.end(), '\0'), output.end());
BOOST_CHECK_EQUAL(output, source);
output =
boost::find_format_all_copy(
source,
boost::first_finder("$noreplace"),
make_checked_formatter(boost::const_formatter("bad")));
BOOST_CHECK_EQUAL(output, source);
// in place version
output = source;
boost::find_format_all(
output,
boost::first_finder("$replace"),
make_checked_formatter(boost::const_formatter("ok")));
BOOST_CHECK_EQUAL(output, expected);
output = source;
boost::find_format_all(
output,
boost::first_finder("$noreplace"),
make_checked_formatter(boost::const_formatter("bad")));
BOOST_CHECK_EQUAL(output, source);
}
int test_main( int, char*[] )
{
find_format_test();
find_format_all_test();
return 0;
}

View File

@ -11,9 +11,6 @@
#include <boost/algorithm/string/erase.hpp> #include <boost/algorithm/string/erase.hpp>
#include <boost/algorithm/string/std/list_traits.hpp> #include <boost/algorithm/string/std/list_traits.hpp>
#include <boost/algorithm/string/std/string_traits.hpp> #include <boost/algorithm/string/std/string_traits.hpp>
#include <boost/algorithm/string/finder.hpp>
#include <boost/algorithm/string/formatter.hpp>
#include <boost/algorithm/string/classification.hpp>
// Include unit test framework // Include unit test framework
#include <boost/test/included/test_exec_monitor.hpp> #include <boost/test/included/test_exec_monitor.hpp>
@ -288,23 +285,6 @@ void collection_comp_test()
} }
} }
void dissect_format_test()
{
BOOST_CHECK(
find_format_all_copy(
string("aBc123Abc"),
first_finder("abc", is_iequal()),
dissect_formatter(token_finder(is_upper())))=="B123A");
BOOST_CHECK(
find_format_all_copy(
string("abc 123 abc"),
token_finder(is_space(), token_compress_on),
dissect_formatter(head_finder(1)))=="abc 123 abc");
}
// test main // test main
int test_main( int, char*[] ) int test_main( int, char*[] )
{ {
@ -317,7 +297,6 @@ int test_main( int, char*[] )
replace_tail_test(); replace_tail_test();
replace_range_test(); replace_range_test();
collection_comp_test(); collection_comp_test();
dissect_format_test();
return 0; return 0;
} }

View File

@ -40,7 +40,6 @@ void iterator_test()
string str1("xx-abc--xx-abb"); string str1("xx-abc--xx-abb");
string str2("Xx-abc--xX-abb-xx"); string str2("Xx-abc--xX-abb-xx");
string str3("xx"); string str3("xx");
string strempty("");
const char* pch1="xx-abc--xx-abb"; const char* pch1="xx-abc--xx-abb";
vector<string> tokens; vector<string> tokens;
vector< vector<int> > vtokens; vector< vector<int> > vtokens;
@ -124,25 +123,6 @@ void iterator_test()
BOOST_CHECK( tokens[3]==string("xx") ); BOOST_CHECK( tokens[3]==string("xx") );
BOOST_CHECK( tokens[4]==string("abb") ); BOOST_CHECK( tokens[4]==string("abb") );
split(
tokens,
str3,
is_any_of(","),
token_compress_off);
BOOST_REQUIRE( tokens.size()==1 );
BOOST_CHECK( tokens[0]==string("xx") );
split(
tokens,
strempty,
is_punct(),
token_compress_off);
BOOST_REQUIRE( tokens.size()==1 );
BOOST_CHECK( tokens[0]==string("") );
find_iterator<string::iterator> fiter=make_find_iterator(str1, first_finder("xx")); find_iterator<string::iterator> fiter=make_find_iterator(str1, first_finder("xx"));
BOOST_CHECK(equals(*fiter, "xx")); BOOST_CHECK(equals(*fiter, "xx"));
++fiter; ++fiter;
@ -159,7 +139,6 @@ void iterator_test()
++siter; ++siter;
BOOST_CHECK(equals(*siter, "abb")); BOOST_CHECK(equals(*siter, "abb"));
++siter; ++siter;
BOOST_CHECK(siter==split_iterator<string::iterator>(siter));
BOOST_CHECK(siter==split_iterator<string::iterator>()); BOOST_CHECK(siter==split_iterator<string::iterator>());
} }

View File

@ -8,7 +8,6 @@
// See http://www.boost.org for updates, documentation, and revision history. // See http://www.boost.org for updates, documentation, and revision history.
#include <boost/algorithm/string/trim.hpp> #include <boost/algorithm/string/trim.hpp>
#include <boost/algorithm/string/trim_all.hpp>
// Include unit test framework // Include unit test framework
#include <boost/test/included/test_exec_monitor.hpp> #include <boost/test/included/test_exec_monitor.hpp>
@ -110,52 +109,10 @@ void trim_test()
BOOST_CHECK( trim_copy_if( string("<>abc<>"), is_any_of( "<<>>" ) )=="abc" ); BOOST_CHECK( trim_copy_if( string("<>abc<>"), is_any_of( "<<>>" ) )=="abc" );
} }
void trim_all_test()
{
string str1(" 1x x x x1 ");
string str2("+---...2x+--x--+x-+-x2...---+");
string str3(" ");
// *** value passing tests *** //
// general string test
BOOST_CHECK( trim_all_copy( str1 )=="1x x x x1" ) ;
BOOST_CHECK( trim_all_copy_if( str2, is_punct() )=="2x+x-x-x2" ) ;
// spaces-only string test
BOOST_CHECK( trim_all_copy( str3 )=="" );
// empty string check
BOOST_CHECK( trim_all_copy( string("") )=="" );
// general string test
trim_all( str1 );
BOOST_CHECK( str1=="1x x x x1" ) ;
trim_all_if( str2, is_punct() );
BOOST_CHECK( str2=="2x+x-x-x2" ) ;
// spaces-only string test
str3 = " "; trim_all( str3 );
BOOST_CHECK( str3=="" );
// empty string check
str3 = ""; trim_all( str3 );
BOOST_CHECK( str3=="" );
BOOST_CHECK( str3=="" );
// *** non-standard predicate tests *** //
BOOST_CHECK(
trim_all_copy_if(
string("123abc127deb456"),
is_classified(std::ctype_base::digit) )=="abc1deb" );
BOOST_CHECK( trim_all_copy_if( string("<>abc<>def<>"), is_any_of( "<<>>" ) )=="abc<def" );
}
// test main // test main
int test_main( int, char*[] ) int test_main( int, char*[] )
{ {
trim_test(); trim_test();
trim_all_test();
return 0; return 0;
} }