1 //////////////////////////////////////////////////////////////////////////////
2 //
3 // (C) Copyright Ion Gaztanaga 2017-2017.
4 // Distributed under the Boost Software License, Version 1.0.
5 // (See accompanying file LICENSE_1_0.txt or copy at
6 // http://www.boost.org/LICENSE_1_0.txt)
7 //
8 // See http://www.boost.org/libs/move for documentation.
9 //
10 //////////////////////////////////////////////////////////////////////////////
11 
12 #ifndef BOOST_MOVE_ALGO_UNIQUE_HPP
13 #define BOOST_MOVE_ALGO_UNIQUE_HPP
14 
15 #include <boost/move/detail/config_begin.hpp>
16 #include <boost/move/utility_core.hpp>
17 
18 namespace boost {
19 namespace movelib {
20 
21 //! <b>Requires</b>: The comparison function shall be an equivalence relation. The type of *first shall satisfy
22 //! the MoveAssignable requirements
23 //!
24 //! <b>Effects</b>: For a nonempty range, eliminates all but the first element from every consecutive group
25 //!   of equivalent elements referred to by the iterator i in the range [first + 1, last) for which the
26 //!   following conditions hold: pred(*(i - 1), *i) != false.
27 //!
28 //! <b>Returns</b>: The end of the resulting range.
29 //!
30 //! <b>Complexity</b>: For nonempty ranges, exactly (last - first) - 1 applications of the corresponding predicate.
31 template<class ForwardIterator, class BinaryPredicate>
unique(ForwardIterator first,ForwardIterator last,BinaryPredicate pred)32 ForwardIterator unique(ForwardIterator first, ForwardIterator last, BinaryPredicate pred)
33 {
34     if (first != last) {
35       ForwardIterator next(first);
36       ++next;
37       for (; next != last; ++next, ++first) {
38          if (pred(*first, *next)) { //Find first equal element
39             while (++next != last)
40                if (!pred(*first, *next))
41                   *++first = ::boost::move(*next);
42             break;
43          }
44       }
45       ++first;
46    }
47    return first;
48 }
49 
50 }  //namespace movelib {
51 }  //namespace boost {
52 
53 #include <boost/move/detail/config_end.hpp>
54 
55 #endif   //#define BOOST_MOVE_ALGO_UNIQUE_HPP
56