// Boost.Geometry Index // // n-dimensional content (hypervolume) - 2d area, 3d volume, ... // // Copyright (c) 2011-2014 Adam Wulkiewicz, Lodz, Poland. // // 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 namespace boost { namespace geometry { namespace index { namespace detail { template struct default_content_result { typedef typename select_most_precise< typename coordinate_type::type, long double >::type 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_MPL_ASSERT_MSG(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