forked from boostorg/algorithm
		
	
		
			
				
	
	
		
			121 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			121 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
//  Boost string_algo library sequence_traits.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_SEQUENCE_TRAITS_HPP
 | 
						|
#define BOOST_STRING_SEQUENCE_TRAITS_HPP
 | 
						|
 | 
						|
#include <boost/config.hpp>
 | 
						|
#include <boost/mpl/bool.hpp>
 | 
						|
#include <boost/algorithm/string/yes_no_type.hpp>
 | 
						|
 | 
						|
/*! \file
 | 
						|
    Traits defined in this header are used by various algorithms to achieve
 | 
						|
    better performance for specific containers.
 | 
						|
    Traits provide fail-safe defaults. If a container supports some of these
 | 
						|
    features, it is possible to specialize the specific trait for this container.
 | 
						|
    For lacking compilers, it is possible of define an override for a specific tester
 | 
						|
    function.
 | 
						|
 | 
						|
    Due to a language restriction, it is not currently possible to define specializations for
 | 
						|
    stl containers without including the corresponding header. To decrease the overhead
 | 
						|
    needed by this inclusion, user can selectively include a specialization
 | 
						|
    header for a specific container. They are located in boost/algorithm/string/stl
 | 
						|
    directory. Alternatively she can include boost/algorithm/string/std_collection_traits.hpp
 | 
						|
    header which contains specializations for all stl containers.
 | 
						|
*/
 | 
						|
 | 
						|
namespace boost {
 | 
						|
    namespace algorithm {
 | 
						|
 | 
						|
//  sequence traits  -----------------------------------------------//
 | 
						|
 | 
						|
 | 
						|
        //! Native replace trait
 | 
						|
        /*!
 | 
						|
            This trait specifies that the sequence has \c std::string like replace method
 | 
						|
        */
 | 
						|
        template< typename T >
 | 
						|
        class has_native_replace
 | 
						|
        {
 | 
						|
 | 
						|
        public:
 | 
						|
#    if BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
            enum { value = false };
 | 
						|
#    else
 | 
						|
            BOOST_STATIC_CONSTANT(bool, value=false);
 | 
						|
#    endif // BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
 | 
						|
 | 
						|
            typedef mpl::bool_<has_native_replace<T>::value> type;
 | 
						|
        };
 | 
						|
 | 
						|
 | 
						|
        //! Stable iterators trait
 | 
						|
        /*!
 | 
						|
            This trait specifies that the sequence has stable iterators. It means
 | 
						|
            that operations like insert/erase/replace do not invalidate iterators.
 | 
						|
        */
 | 
						|
        template< typename T >
 | 
						|
        class has_stable_iterators
 | 
						|
        {
 | 
						|
        public:
 | 
						|
#    if BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
            enum { value = false };
 | 
						|
#    else
 | 
						|
            BOOST_STATIC_CONSTANT(bool, value=false);
 | 
						|
#    endif // BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
 | 
						|
            typedef mpl::bool_<has_stable_iterators<T>::value> type;
 | 
						|
        };
 | 
						|
 | 
						|
 | 
						|
        //! Const time insert trait
 | 
						|
        /*!
 | 
						|
            This trait specifies that the sequence's insert method has
 | 
						|
            constant time complexity.
 | 
						|
        */
 | 
						|
        template< typename T >
 | 
						|
        class has_const_time_insert
 | 
						|
        {
 | 
						|
        public:
 | 
						|
#    if BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
            enum { value = false };
 | 
						|
#    else
 | 
						|
            BOOST_STATIC_CONSTANT(bool, value=false);
 | 
						|
#    endif // BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
 | 
						|
            typedef mpl::bool_<has_const_time_insert<T>::value> type;
 | 
						|
        };
 | 
						|
 | 
						|
 | 
						|
        //! Const time erase trait
 | 
						|
        /*!
 | 
						|
            This trait specifies that the sequence's erase method has
 | 
						|
            constant time complexity.
 | 
						|
        */
 | 
						|
        template< typename T >
 | 
						|
        class has_const_time_erase
 | 
						|
        {
 | 
						|
        public:
 | 
						|
#    if BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
            enum { value = false };
 | 
						|
#    else
 | 
						|
            BOOST_STATIC_CONSTANT(bool, value=false);
 | 
						|
#    endif // BOOST_WORKAROUND( __IBMCPP__, <= 600 )
 | 
						|
 | 
						|
            typedef mpl::bool_<has_const_time_erase<T>::value> type;
 | 
						|
        };
 | 
						|
 | 
						|
    } // namespace algorithm
 | 
						|
} // namespace boost
 | 
						|
 | 
						|
 | 
						|
#endif  // BOOST_STRING_SEQUENCE_TRAITS_HPP
 |