mirror of
https://github.com/bolero-MURAKAMI/Sprout.git
synced 2025-01-23 20:46:37 +00:00
50 lines
1.5 KiB
C++
50 lines
1.5 KiB
C++
#ifndef SPROUT_ITERATOR_UNIQUE_ITERATOR_HPP
|
|
#define SPROUT_ITERATOR_UNIQUE_ITERATOR_HPP
|
|
|
|
#include <sprout/config.hpp>
|
|
#include <sprout/iterator/adjacent_filter_iterator.hpp>
|
|
#include <sprout/functional/equal_to.hpp>
|
|
|
|
namespace sprout {
|
|
//
|
|
// unique_filter
|
|
//
|
|
template<typename Predicate = sprout::equal_to<> >
|
|
class unique_filter {
|
|
public:
|
|
typedef bool result_type;
|
|
private:
|
|
Predicate pred_;
|
|
public:
|
|
SPROUT_CONSTEXPR unique_filter()
|
|
: pred_()
|
|
{}
|
|
explicit SPROUT_CONSTEXPR unique_filter(Predicate pred)
|
|
: pred_(pred)
|
|
{}
|
|
template<typename T, typename U>
|
|
SPROUT_CONSTEXPR bool operator()(T const& lhs, U const& rhs) const {
|
|
return !pred_(lhs, rhs);
|
|
}
|
|
};
|
|
|
|
//
|
|
// make_unique_iterator
|
|
//
|
|
template<typename Predicate, typename Iterator>
|
|
inline SPROUT_CONSTEXPR sprout::adjacent_filter_iterator<sprout::unique_filter<Predicate>, Iterator>
|
|
make_unique_iterator(Predicate pred, Iterator it, Iterator last = Iterator()) {
|
|
return sprout::adjacent_filter_iterator<sprout::unique_filter<Predicate>, Iterator>(
|
|
sprout::unique_filter<Predicate>(pred), it, last
|
|
);
|
|
}
|
|
template<typename Iterator>
|
|
inline SPROUT_CONSTEXPR sprout::adjacent_filter_iterator<sprout::unique_filter<>, Iterator>
|
|
make_unique_iterator(Iterator it, Iterator last = Iterator()) {
|
|
return sprout::adjacent_filter_iterator<sprout::unique_filter<>, Iterator>(
|
|
sprout::unique_filter<>(), it, last
|
|
);
|
|
}
|
|
} // namespace sprout
|
|
|
|
#endif // SPROUT_ITERATOR_UNIQUE_ITERATOR_HPP
|