////////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2016-2016. 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/libs/container for documentation. // ////////////////////////////////////////////////////////////////////////////// #ifndef BOOST_CONTAINER_DETAIL_IS_SORTED_HPP #define BOOST_CONTAINER_DETAIL_IS_SORTED_HPP #ifndef BOOST_CONFIG_HPP # include #endif #if defined(BOOST_HAS_PRAGMA_ONCE) # pragma once #endif namespace boost { namespace container { namespace container_detail { template bool is_sorted (ForwardIterator first, ForwardIterator last, Pred pred) { if(first != last){ ForwardIterator next = first; while (++next != last){ if(pred(*next, *first)) return false; ++first; } } return true; } template bool is_sorted_and_unique (ForwardIterator first, ForwardIterator last, Pred pred) { if(first != last){ ForwardIterator next = first; while (++next != last){ if(!pred(*first, *next)) return false; ++first; } } return true; } } //namespace container_detail { } //namespace container { } //namespace boost { #endif //#ifndef BOOST_CONTAINER_DETAIL_IS_SORTED_HPP