Sha256: 689a8d5cf485fbf0ea19e329f6c8a343d96dc895ac062a54abe52b18106f3616

Contents?: true

Size: 1.85 KB

Versions: 27

Compression:

Stored size: 1.85 KB

Contents

//////////////////////////////////////////////////////////////////////////////
//
// (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

Version data entries

27 entries across 27 versions & 1 rubygems

Version Path
passenger-6.0.24 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.23 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.20 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.19 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.18 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.17 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.16 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.15 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.14 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.13 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.12 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.11 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.10 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.9 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.8 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.7 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.6 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.5 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.4 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp
passenger-6.0.3 src/cxx_supportlib/vendor-modified/boost/move/algo/unique.hpp