diff options
Diffstat (limited to 'boost/geometry/algorithms/detail/is_valid/has_duplicates.hpp')
-rw-r--r-- | boost/geometry/algorithms/detail/is_valid/has_duplicates.hpp | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/boost/geometry/algorithms/detail/is_valid/has_duplicates.hpp b/boost/geometry/algorithms/detail/is_valid/has_duplicates.hpp new file mode 100644 index 0000000000..dd0922bb2b --- /dev/null +++ b/boost/geometry/algorithms/detail/is_valid/has_duplicates.hpp @@ -0,0 +1,70 @@ +// Boost.Geometry (aka GGL, Generic Geometry Library) + +// Copyright (c) 2014, Oracle and/or its affiliates. + +// Contributed and/or modified by Menelaos Karavelas, on behalf of Oracle + +// Licensed under the Boost Software License version 1.0. +// http://www.boost.org/users/license.html + +#ifndef BOOST_GEOMETRY_ALGORITHMS_DETAIL_IS_VALID_HAS_DUPLICATES_HPP +#define BOOST_GEOMETRY_ALGORITHMS_DETAIL_IS_VALID_HAS_DUPLICATES_HPP + +#include <boost/range.hpp> + +#include <boost/geometry/core/closure.hpp> + +#include <boost/geometry/policies/compare.hpp> + +#include <boost/geometry/views/closeable_view.hpp> + + +namespace boost { namespace geometry +{ + + +#ifndef DOXYGEN_NO_DETAIL +namespace detail { namespace is_valid +{ + +template <typename Range, closure_selector Closure> +struct has_duplicates +{ + static inline bool apply(Range const& range) + { + typedef typename closeable_view<Range const, Closure>::type view_type; + typedef typename boost::range_iterator<view_type const>::type iterator; + + view_type view(range); + + if ( boost::size(view) < 2 ) + { + return false; + } + + geometry::equal_to<typename boost::range_value<Range>::type> equal; + + iterator it = boost::begin(view); + iterator next = ++boost::begin(view); + for (; next != boost::end(view); ++it, ++next) + { + if ( equal(*it, *next) ) + { + return true; + } + } + return false; + } +}; + + + +}} // namespace detail::is_valid +#endif // DOXYGEN_NO_DETAIL + + +}} // namespace boost::geometry + + + +#endif // BOOST_GEOMETRY_ALGORITHMS_DETAIL_IS_VALID_HAS_DUPLICATES_HPP |