// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2007-2012 Barend Gehrels, Amsterdam, the Netherlands. // Copyright (c) 2008-2012 Bruno Lalande, Paris, France. // Copyright (c) 2009-2012 Mateusz Loskot, London, UK. // This file was modified by Oracle on 2013-2022. // Modifications copyright (c) 2013-2022 Oracle and/or its affiliates. // Contributed and/or modified by Vissarion Fysikopoulos, on behalf of Oracle // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle // Parts of Boost.Geometry are redesigned from Geodan's Geographic Library // (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands. // Use, modification and distribution is subject to 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) #ifndef BOOST_GEOMETRY_ALGORITHMS_DETAIL_COVERED_BY_IMPLEMENTATION_HPP #define BOOST_GEOMETRY_ALGORITHMS_DETAIL_COVERED_BY_IMPLEMENTATION_HPP #include #include #include #include #include #include #include namespace boost { namespace geometry { #ifndef DOXYGEN_NO_DETAIL namespace detail { namespace covered_by { struct use_point_in_geometry { template static inline bool apply(Geometry1 const& geometry1, Geometry2 const& geometry2, Strategy const& strategy) { return detail::within::covered_by_point_geometry(geometry1, geometry2, strategy); } }; struct use_relate { template static inline bool apply(Geometry1 const& geometry1, Geometry2 const& geometry2, Strategy const& strategy) { return detail::relate::relate_impl < detail::de9im::static_mask_covered_by_type, Geometry1, Geometry2 >::apply(geometry1, geometry2, strategy); } }; struct geometry_covered_by_box { template static inline bool apply(Geometry const& geometry, Box const& box, Strategy const& strategy) { using point_type = typename point_type::type; using mutable_point_type = typename helper_geometry::type; using box_type = model::box; // TODO: this is not optimal since the process should be able to terminate if a point is found // outside of the box without computing the whole envelope box_type box_areal; geometry::envelope(geometry, box_areal, strategy); return strategy.covered_by(box_areal, box).apply(box_areal, box); } }; }} // namespace detail::covered_by #endif // DOXYGEN_NO_DETAIL #ifndef DOXYGEN_NO_DISPATCH namespace dispatch { // P/P template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::within::multi_point_point {}; template struct covered_by : public detail::within::multi_point_multi_point {}; // P/L template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::within::multi_point_single_geometry {}; template struct covered_by : public detail::within::multi_point_single_geometry {}; template struct covered_by : public detail::within::multi_point_multi_geometry {}; // P/A template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::covered_by::use_point_in_geometry {}; template struct covered_by : public detail::within::multi_point_single_geometry {}; template struct covered_by : public detail::within::multi_point_single_geometry {}; template struct covered_by : public detail::within::multi_point_multi_geometry {}; // L/L template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; // L/A template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; // A/A template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; // B/A template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; template struct covered_by : public detail::covered_by::use_relate {}; // Geometry/Box template struct covered_by { template static inline bool apply(Point const& point, Box const& box, Strategy const& strategy) { return strategy.covered_by(point, box).apply(point, box); } }; template struct covered_by : public detail::covered_by::geometry_covered_by_box {}; template struct covered_by : public detail::covered_by::geometry_covered_by_box {}; template struct covered_by : public detail::covered_by::geometry_covered_by_box {}; template struct covered_by : public detail::covered_by::geometry_covered_by_box {}; template struct covered_by : public detail::covered_by::geometry_covered_by_box {}; template struct covered_by : public detail::covered_by::geometry_covered_by_box {}; template struct covered_by { template static inline bool apply(Box1 const& box1, Box2 const& box2, Strategy const& strategy) { assert_dimension_equal(); return strategy.covered_by(box1, box2).apply(box1, box2); } }; } // namespace dispatch #endif // DOXYGEN_NO_DISPATCH }} // namespace boost::geometry #endif // BOOST_GEOMETRY_ALGORITHMS_DETAIL_COVERED_BY_IMPLEMENTATION_HPP