123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- // Boost string_algo library util.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_UTIL_DETAIL_HPP
- #define BOOST_STRING_UTIL_DETAIL_HPP
- #include <boost/algorithm/string/config.hpp>
- #include <functional>
- #include <boost/range/iterator_range_core.hpp>
- namespace boost {
- namespace algorithm {
- namespace detail {
- // empty container -----------------------------------------------//
- // empty_container
- /*
- This class represents always empty container,
- containing elements of type CharT.
- It is supposed to be used in a const version only
- */
- template< typename CharT >
- struct empty_container
- {
- typedef empty_container<CharT> type;
- typedef CharT value_type;
- typedef std::size_t size_type;
- typedef std::ptrdiff_t difference_type;
- typedef const value_type& reference;
- typedef const value_type& const_reference;
- typedef const value_type* iterator;
- typedef const value_type* const_iterator;
-
- // Operations
- const_iterator begin() const
- {
- return reinterpret_cast<const_iterator>(0);
- }
- const_iterator end() const
- {
- return reinterpret_cast<const_iterator>(0);
- }
- bool empty() const
- {
- return false;
- }
- size_type size() const
- {
- return 0;
- }
- };
-
- // bounded copy algorithm -----------------------------------------------//
- // Bounded version of the std::copy algorithm
- template<typename InputIteratorT, typename OutputIteratorT>
- inline OutputIteratorT bounded_copy(
- InputIteratorT First,
- InputIteratorT Last,
- OutputIteratorT DestFirst,
- OutputIteratorT DestLast )
- {
- InputIteratorT InputIt=First;
- OutputIteratorT OutputIt=DestFirst;
- for(; InputIt!=Last && OutputIt!=DestLast; InputIt++, OutputIt++ )
- {
- *OutputIt=*InputIt;
- }
- return OutputIt;
- }
- // iterator range utilities -----------------------------------------//
- // copy range functor
- template<
- typename SeqT,
- typename IteratorT=BOOST_STRING_TYPENAME SeqT::const_iterator >
- struct copy_iterator_rangeF
- {
- typedef iterator_range<IteratorT> argument_type;
- typedef SeqT result_type;
- SeqT operator()( const iterator_range<IteratorT>& Range ) const
- {
- return copy_range<SeqT>(Range);
- }
- };
- } // namespace detail
- } // namespace algorithm
- } // namespace boost
- #endif // BOOST_STRING_UTIL_DETAIL_HPP
|