// Boost.Geometry Index // // n-dimensional content (hypervolume) - 2d area, 3d volume, ... // // Copyright (c) 2011-2014 Adam Wulkiewicz, Lodz, Poland. // // This file was modified by Oracle on 2020-2022. // Modifications copyright (c) 2020-2022 Oracle and/or its affiliates. // 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_INDEX_DETAIL_ALGORITHMS_CONTENT_HPP #define BOOST_GEOMETRY_INDEX_DETAIL_ALGORITHMS_CONTENT_HPP #include #include #include #include #include #include namespace boost { namespace geometry { namespace index { namespace detail { template struct default_content_result { using type = typename select_most_precise < typename coordinate_type::type, double >::type; }; namespace dispatch { template ::value> struct content_box { BOOST_STATIC_ASSERT(0 < CurrentDimension); static inline typename detail::default_content_result::type apply(Box const& b) { return content_box::apply(b) * ( get(b) - get(b) ); } }; template struct content_box { static inline typename detail::default_content_result::type apply(Box const& b) { return get(b) - get(b); } }; template struct content { BOOST_GEOMETRY_STATIC_ASSERT_FALSE( "Not implemented for this Indexable and Tag.", Indexable, Tag); }; template struct content { static typename detail::default_content_result::type apply(Indexable const&) { return 0; } }; template struct content { static typename default_content_result::type apply(Indexable const& b) { return dispatch::content_box::apply(b); } }; } // namespace dispatch template typename default_content_result::type content(Indexable const& b) { return dispatch::content < Indexable, typename tag::type >::apply(b); } }}}} // namespace boost::geometry::index::detail #endif // BOOST_GEOMETRY_INDEX_DETAIL_ALGORITHMS_CONTENT_HPP