| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 | ////////////////////////////////////////////////////////////////////////////////// (C) Copyright Ion Gaztanaga 2017-2017.// 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/move for documentation.////////////////////////////////////////////////////////////////////////////////#ifndef BOOST_MOVE_ALGO_UNIQUE_HPP#define BOOST_MOVE_ALGO_UNIQUE_HPP#include <boost/move/detail/config_begin.hpp>#include <boost/move/utility_core.hpp>namespace boost {namespace movelib {//! <b>Requires</b>: The comparison function shall be an equivalence relation. The type of *first shall satisfy//! the MoveAssignable requirements//!//! <b>Effects</b>: For a nonempty range, eliminates all but the first element from every consecutive group//!   of equivalent elements referred to by the iterator i in the range [first + 1, last) for which the//!   following conditions hold: pred(*(i - 1), *i) != false.//!//! <b>Returns</b>: The end of the resulting range.//!//! <b>Complexity</b>: For nonempty ranges, exactly (last - first) - 1 applications of the corresponding predicate.template<class ForwardIterator, class BinaryPredicate>ForwardIterator unique(ForwardIterator first, ForwardIterator last, BinaryPredicate pred){    if (first != last) {      ForwardIterator next(first);      ++next;      for (; next != last; ++next, ++first) {         if (pred(*first, *next)) { //Find first equal element            while (++next != last)               if (!pred(*first, *next))                  *++first = ::boost::move(*next);            break;         }      }      ++first;   }   return first;}}  //namespace movelib {}  //namespace boost {#include <boost/move/detail/config_end.hpp>#endif   //#define BOOST_MOVE_ALGO_UNIQUE_HPP
 |