// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2015-2021, Oracle and/or its affiliates. // Contributed and/or modified by Vissarion Fysikopoulos, on behalf of Oracle // Contributed and/or modified by Menelaos Karavelas, on behalf of Oracle // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle // Licensed under the Boost Software License version 1.0. // http://www.boost.org/users/license.html #ifndef BOOST_GEOMETRY_ALGORITHMS_IS_EMPTY_HPP #define BOOST_GEOMETRY_ALGORITHMS_IS_EMPTY_HPP #include #include #include #include #include #include #include #include #include #include #include #include // For backward compatibility #include #include namespace boost { namespace geometry { #ifndef DOXYGEN_NO_DETAIL namespace detail { namespace is_empty { struct always_not_empty { template static inline bool apply(Geometry const&) { return false; } }; struct range_is_empty { template static inline bool apply(Range const& range) { return boost::empty(range); } }; class polygon_is_empty { template static inline bool check_interior_rings(InteriorRings const& interior_rings) { return std::all_of(boost::begin(interior_rings), boost::end(interior_rings), []( auto const& range ){ return boost::empty(range); }); } public: template static inline bool apply(Polygon const& polygon) { return boost::empty(exterior_ring(polygon)) && check_interior_rings(interior_rings(polygon)); } }; template struct multi_is_empty { template static inline bool apply(MultiGeometry const& multigeometry) { return std::all_of(boost::begin(multigeometry), boost::end(multigeometry), []( auto const& range ){ return Policy::apply(range); }); } }; }} // namespace detail::is_empty #endif // DOXYGEN_NO_DETAIL #ifndef DOXYGEN_NO_DISPATCH namespace dispatch { template ::type> struct is_empty : not_implemented {}; template struct is_empty : detail::is_empty::always_not_empty {}; template struct is_empty : detail::is_empty::always_not_empty {}; template struct is_empty : detail::is_empty::always_not_empty {}; template struct is_empty : detail::is_empty::range_is_empty {}; template struct is_empty : detail::is_empty::range_is_empty {}; template struct is_empty : detail::is_empty::polygon_is_empty {}; template struct is_empty : detail::is_empty::range_is_empty {}; template struct is_empty : detail::is_empty::multi_is_empty<> {}; template struct is_empty : detail::is_empty::multi_is_empty {}; } // namespace dispatch #endif // DOXYGEN_NO_DISPATCH namespace resolve_dynamic { template ::type> struct is_empty { static inline bool apply(Geometry const& geometry) { concepts::check(); return dispatch::is_empty::apply(geometry); } }; template struct is_empty { static inline bool apply(Geometry const& geometry) { bool result = true; traits::visit::apply([&](auto const& g) { result = is_empty>::apply(g); }, geometry); return result; } }; template struct is_empty { static inline bool apply(Geometry const& geometry) { bool result = true; detail::visit_breadth_first([&](auto const& g) { result = is_empty>::apply(g); return result; }, geometry); return result; } }; } // namespace resolve_dynamic /*! \brief \brief_check{is the empty set} \ingroup is_empty \tparam Geometry \tparam_geometry \param geometry \param_geometry \return \return_check{is the empty set} \qbk{[include reference/algorithms/is_empty.qbk]} */ template inline bool is_empty(Geometry const& geometry) { return resolve_dynamic::is_empty::apply(geometry); } }} // namespace boost::geometry #endif // BOOST_GEOMETRY_ALGORITHMS_IS_EMPTY_HPP