// 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. // Parts of Boost.Geometry are redesigned from Geodan's Geographic Library // (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands. // This file was modified by Oracle on 2018-2021. // Modifications copyright (c) 2018-2021, 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 // 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_ASSIGN_VALUES_HPP #define BOOST_GEOMETRY_ALGORITHMS_ASSIGN_VALUES_HPP #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace geometry { #ifndef DOXYGEN_NO_DETAIL namespace detail { namespace assign { struct assign_zero_point { template static inline void apply(Point& point) { typedef typename coordinate_type::type coordinate_type; coordinate_type const zero = 0; detail::for_each_dimension([&](auto dimension) { set(point, zero); }); } }; struct assign_inverse_box_or_segment { template static inline void apply(BoxOrSegment& geometry) { typedef typename coordinate_type::type coordinate_type; coordinate_type const highest = util::bounds::highest(); coordinate_type const lowest = util::bounds::lowest(); detail::for_each_dimension([&](auto dimension) { set<0, dimension>(geometry, highest); set<1, dimension>(geometry, lowest); }); } }; struct assign_zero_box_or_segment { template static inline void apply(BoxOrSegment& geometry) { typedef typename coordinate_type::type coordinate_type; coordinate_type const zero = 0; detail::for_each_dimension([&](auto dimension) { set<0, dimension>(geometry, zero); set<1, dimension>(geometry, zero); }); } }; template < std::size_t Corner1, std::size_t Corner2, typename Box, typename Point > inline void assign_box_2d_corner(Box const& box, Point& point) { // Be sure both are 2-Dimensional assert_dimension(); assert_dimension(); // Copy coordinates typedef typename coordinate_type::type coordinate_type; geometry::set<0>(point, util::numeric_cast(get(box))); geometry::set<1>(point, util::numeric_cast(get(box))); } template struct assign_2d_box_or_segment { typedef typename coordinate_type::type coordinate_type; // Here we assign 4 coordinates to a box of segment // -> Most logical is: x1,y1,x2,y2 // In case the user reverses x1/x2 or y1/y2, for a box, we could reverse them (THAT IS NOT IMPLEMENTED) template static inline void apply(Geometry& geometry, Type const& x1, Type const& y1, Type const& x2, Type const& y2) { geometry::set<0, 0>(geometry, util::numeric_cast(x1)); geometry::set<0, 1>(geometry, util::numeric_cast(y1)); geometry::set<1, 0>(geometry, util::numeric_cast(x2)); geometry::set<1, 1>(geometry, util::numeric_cast(y2)); } }; }} // namespace detail::assign #endif // DOXYGEN_NO_DETAIL #ifndef DOXYGEN_NO_DISPATCH namespace dispatch { template struct assign { BOOST_GEOMETRY_STATIC_ASSERT_FALSE( "Not or not yet implemented for this Geometry type.", GeometryTag, Geometry, std::integral_constant); }; template struct assign { typedef typename coordinate_type::type coordinate_type; template static inline void apply(Point& point, T const& c1, T const& c2) { set<0>(point, util::numeric_cast(c1)); set<1>(point, util::numeric_cast(c2)); } }; template struct assign { typedef typename coordinate_type::type coordinate_type; template static inline void apply(Point& point, T const& c1, T const& c2, T const& c3) { set<0>(point, util::numeric_cast(c1)); set<1>(point, util::numeric_cast(c2)); set<2>(point, util::numeric_cast(c3)); } }; template struct assign : detail::assign::assign_2d_box_or_segment {}; template struct assign : detail::assign::assign_2d_box_or_segment {}; template struct assign_zero {}; template struct assign_zero : detail::assign::assign_zero_point {}; template struct assign_zero : detail::assign::assign_zero_box_or_segment {}; template struct assign_zero : detail::assign::assign_zero_box_or_segment {}; template struct assign_inverse {}; template struct assign_inverse : detail::assign::assign_inverse_box_or_segment {}; template struct assign_inverse : detail::assign::assign_inverse_box_or_segment {}; } // namespace dispatch #endif // DOXYGEN_NO_DISPATCH }} // namespace boost::geometry #endif // BOOST_GEOMETRY_ALGORITHMS_ASSIGN_VALUES_HPP