57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
/*==============================================================================
 | 
						|
    Copyright (c) 2010-2011 Bryce Lelbach
 | 
						|
 | 
						|
    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)
 | 
						|
==============================================================================*/
 | 
						|
 | 
						|
#ifndef BOOST_DETAIL_SORTED_HPP
 | 
						|
#define BOOST_DETAIL_SORTED_HPP
 | 
						|
 | 
						|
#include <boost/detail/iterator.hpp>
 | 
						|
 | 
						|
#include <functional>
 | 
						|
 | 
						|
namespace boost {
 | 
						|
namespace detail {
 | 
						|
 | 
						|
template<class Iterator, class Comp>
 | 
						|
inline Iterator is_sorted_until (Iterator first, Iterator last, Comp c) {
 | 
						|
  if (first == last)
 | 
						|
    return last;
 | 
						|
 | 
						|
  Iterator it = first; ++it;
 | 
						|
 | 
						|
  for (; it != last; first = it, ++it)
 | 
						|
    if (c(*it, *first))
 | 
						|
      return it;
 | 
						|
 | 
						|
  return it;
 | 
						|
}
 | 
						|
 | 
						|
template<class Iterator>
 | 
						|
inline Iterator is_sorted_until (Iterator first, Iterator last) {
 | 
						|
  typedef typename boost::detail::iterator_traits<Iterator>::value_type
 | 
						|
    value_type;
 | 
						|
 | 
						|
  typedef std::less<value_type> c; 
 | 
						|
 | 
						|
  return ::boost::detail::is_sorted_until(first, last, c()); 
 | 
						|
}
 | 
						|
 | 
						|
template<class Iterator, class Comp>
 | 
						|
inline bool is_sorted (Iterator first, Iterator last, Comp c) {
 | 
						|
  return ::boost::detail::is_sorted_until(first, last, c) == last;
 | 
						|
} 
 | 
						|
 | 
						|
template<class Iterator>
 | 
						|
inline bool is_sorted (Iterator first, Iterator last) {
 | 
						|
  return ::boost::detail::is_sorted_until(first, last) == last;
 | 
						|
} 
 | 
						|
 | 
						|
} // detail
 | 
						|
} // boost
 | 
						|
 | 
						|
#endif // BOOST_DETAIL_SORTED_HPP
 | 
						|
 |