200 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			200 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | //  Boost string_algo library compare.hpp header file  -------------------------// | ||
|  | 
 | ||
|  | //  Copyright Pavol Droba 2002-2006. | ||
|  | // | ||
|  | // 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_COMPARE_HPP | ||
|  | #define BOOST_STRING_COMPARE_HPP | ||
|  | 
 | ||
|  | #include <boost/algorithm/string/config.hpp> | ||
|  | #include <locale> | ||
|  | 
 | ||
|  | /*! \file | ||
|  |     Defines element comparison predicates. Many algorithms in this library can | ||
|  |     take an additional argument with a predicate used to compare elements. | ||
|  |     This makes it possible, for instance, to have case insensitive versions | ||
|  |     of the algorithms. | ||
|  | */ | ||
|  | 
 | ||
|  | namespace boost { | ||
|  |     namespace algorithm { | ||
|  | 
 | ||
|  |         //  is_equal functor  -----------------------------------------------// | ||
|  | 
 | ||
|  |         //! is_equal functor | ||
|  |         /*! | ||
|  |             Standard STL equal_to only handle comparison between arguments | ||
|  |             of the same type. This is a less restrictive version which wraps operator ==. | ||
|  |         */ | ||
|  |         struct is_equal | ||
|  |         { | ||
|  |             //! Function operator | ||
|  |             /*! | ||
|  |                 Compare two operands for equality | ||
|  |             */ | ||
|  |             template< typename T1, typename T2 > | ||
|  |                 bool operator()( const T1& Arg1, const T2& Arg2 ) const | ||
|  |             { | ||
|  |                 return Arg1==Arg2; | ||
|  |             } | ||
|  |         }; | ||
|  | 
 | ||
|  |         //! case insensitive version of is_equal | ||
|  |         /*! | ||
|  |             Case insensitive comparison predicate. Comparison is done using | ||
|  |             specified locales. | ||
|  |         */ | ||
|  |         struct is_iequal | ||
|  |         { | ||
|  |             //! Constructor | ||
|  |             /*! | ||
|  |                 \param Loc locales used for comparison | ||
|  |             */ | ||
|  |             is_iequal( const std::locale& Loc=std::locale() ) : | ||
|  |                 m_Loc( Loc ) {} | ||
|  | 
 | ||
|  |             //! Function operator | ||
|  |             /*! | ||
|  |                 Compare two operands. Case is ignored. | ||
|  |             */ | ||
|  |             template< typename T1, typename T2 > | ||
|  |                 bool operator()( const T1& Arg1, const T2& Arg2 ) const | ||
|  |             { | ||
|  |                 #if defined(__BORLANDC__) && (__BORLANDC__ >= 0x560) && (__BORLANDC__ <= 0x564) && !defined(_USE_OLD_RW_STL) | ||
|  |                     return std::toupper(Arg1)==std::toupper(Arg2); | ||
|  |                 #else | ||
|  |                     return std::toupper<T1>(Arg1,m_Loc)==std::toupper<T2>(Arg2,m_Loc); | ||
|  |                 #endif | ||
|  |             } | ||
|  | 
 | ||
|  |         private: | ||
|  |             std::locale m_Loc; | ||
|  |         }; | ||
|  | 
 | ||
|  |         //  is_less functor  -----------------------------------------------// | ||
|  | 
 | ||
|  |         //! is_less functor | ||
|  |         /*! | ||
|  |             Convenient version of standard std::less. Operation is templated, therefore it is  | ||
|  |             not required to specify the exact types upon the construction | ||
|  |          */ | ||
|  |         struct is_less | ||
|  |         { | ||
|  |             //! Functor operation | ||
|  |             /*! | ||
|  |                 Compare two operands using > operator | ||
|  |              */ | ||
|  |             template< typename T1, typename T2 > | ||
|  |                 bool operator()( const T1& Arg1, const T2& Arg2 ) const | ||
|  |             { | ||
|  |                 return Arg1<Arg2; | ||
|  |             } | ||
|  |         }; | ||
|  | 
 | ||
|  | 
 | ||
|  |         //! case insensitive version of is_less | ||
|  |         /*! | ||
|  |             Case insensitive comparison predicate. Comparison is done using | ||
|  |             specified locales. | ||
|  |         */ | ||
|  |         struct is_iless | ||
|  |         { | ||
|  |             //! Constructor | ||
|  |             /*! | ||
|  |                 \param Loc locales used for comparison | ||
|  |             */ | ||
|  |             is_iless( const std::locale& Loc=std::locale() ) : | ||
|  |                 m_Loc( Loc ) {} | ||
|  | 
 | ||
|  |             //! Function operator | ||
|  |             /*! | ||
|  |                 Compare two operands. Case is ignored. | ||
|  |             */ | ||
|  |             template< typename T1, typename T2 > | ||
|  |                 bool operator()( const T1& Arg1, const T2& Arg2 ) const | ||
|  |             { | ||
|  |                 #if defined(__BORLANDC__) && (__BORLANDC__ >= 0x560) && (__BORLANDC__ <= 0x564) && !defined(_USE_OLD_RW_STL) | ||
|  |                     return std::toupper(Arg1)<std::toupper(Arg2); | ||
|  |                 #else | ||
|  |                     return std::toupper<T1>(Arg1,m_Loc)<std::toupper<T2>(Arg2,m_Loc); | ||
|  |                 #endif | ||
|  |             } | ||
|  | 
 | ||
|  |         private: | ||
|  |             std::locale m_Loc; | ||
|  |         }; | ||
|  | 
 | ||
|  |         //  is_not_greater functor  -----------------------------------------------// | ||
|  | 
 | ||
|  |         //! is_not_greater functor | ||
|  |         /*! | ||
|  |             Convenient version of standard std::not_greater_to. Operation is templated, therefore it is  | ||
|  |             not required to specify the exact types upon the construction | ||
|  |          */ | ||
|  |         struct is_not_greater | ||
|  |         { | ||
|  |             //! Functor operation | ||
|  |             /*! | ||
|  |                 Compare two operands using > operator | ||
|  |              */ | ||
|  |             template< typename T1, typename T2 > | ||
|  |                 bool operator()( const T1& Arg1, const T2& Arg2 ) const | ||
|  |             { | ||
|  |                 return Arg1<=Arg2; | ||
|  |             } | ||
|  |         }; | ||
|  | 
 | ||
|  | 
 | ||
|  |         //! case insensitive version of is_not_greater | ||
|  |         /*! | ||
|  |             Case insensitive comparison predicate. Comparison is done using | ||
|  |             specified locales. | ||
|  |         */ | ||
|  |         struct is_not_igreater | ||
|  |         { | ||
|  |             //! Constructor | ||
|  |             /*! | ||
|  |                 \param Loc locales used for comparison | ||
|  |             */ | ||
|  |             is_not_igreater( const std::locale& Loc=std::locale() ) : | ||
|  |                 m_Loc( Loc ) {} | ||
|  | 
 | ||
|  |             //! Function operator | ||
|  |             /*! | ||
|  |                 Compare two operands. Case is ignored. | ||
|  |             */ | ||
|  |             template< typename T1, typename T2 > | ||
|  |                 bool operator()( const T1& Arg1, const T2& Arg2 ) const | ||
|  |             { | ||
|  |                 #if defined(__BORLANDC__) && (__BORLANDC__ >= 0x560) && (__BORLANDC__ <= 0x564) && !defined(_USE_OLD_RW_STL) | ||
|  |                     return std::toupper(Arg1)<=std::toupper(Arg2); | ||
|  |                 #else | ||
|  |                     return std::toupper<T1>(Arg1,m_Loc)<=std::toupper<T2>(Arg2,m_Loc); | ||
|  |                 #endif | ||
|  |             } | ||
|  | 
 | ||
|  |         private: | ||
|  |             std::locale m_Loc; | ||
|  |         }; | ||
|  | 
 | ||
|  | 
 | ||
|  |     } // namespace algorithm | ||
|  | 
 | ||
|  |     // pull names to the boost namespace | ||
|  |     using algorithm::is_equal; | ||
|  |     using algorithm::is_iequal; | ||
|  |     using algorithm::is_less; | ||
|  |     using algorithm::is_iless; | ||
|  |     using algorithm::is_not_greater; | ||
|  |     using algorithm::is_not_igreater; | ||
|  | 
 | ||
|  | } // namespace boost | ||
|  | 
 | ||
|  | 
 | ||
|  | #endif  // BOOST_STRING_COMPARE_HPP |