// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2007-2012 Barend Gehrels, Amsterdam, the Netherlands. // This file was modified by Oracle on 2013, 2014. // Modifications copyright (c) 2013-2014, Oracle and/or its affiliates. // 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) // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle #ifndef BOOST_GEOMETRY_ALGORITHMS_DETAIL_SUB_RANGE_HPP #define BOOST_GEOMETRY_ALGORITHMS_DETAIL_SUB_RANGE_HPP #include namespace boost { namespace geometry { #ifndef DOXYGEN_NO_DETAIL #ifndef DOXYGEN_NO_DISPATCH namespace detail_dispatch { template ::type, bool IsMulti = boost::is_base_of::value> struct sub_range : not_implemented {}; template struct sub_range { typedef Geometry & return_type; template static inline return_type apply(Geometry & geometry, Id const&) { return geometry; } }; template struct sub_range { typedef typename geometry::ring_type::type & return_type; template static inline return_type apply(Geometry & geometry, Id const& id) { if ( id.ring_index < 0 ) { return geometry::exterior_ring(geometry); } else { std::size_t ri = static_cast(id.ring_index); return range::at(geometry::interior_rings(geometry), ri); } } }; template struct sub_range { typedef typename boost::range_value::type value_type; typedef typename boost::mpl::if_c < boost::is_const::value, typename boost::add_const::type, value_type >::type sub_type; typedef detail_dispatch::sub_range sub_sub_range; // TODO: shouldn't it be return_type? typedef typename sub_sub_range::return_type return_type; template static inline return_type apply(Geometry & geometry, Id const& id) { BOOST_ASSERT(0 <= id.multi_index); return sub_sub_range::apply(range::at(geometry, id.multi_index), id); } }; } // namespace detail_dispatch #endif // DOXYGEN_NO_DISPATCH namespace detail { template struct sub_range_return_type { typedef typename detail_dispatch::sub_range::return_type type; }; // This function also works for geometry::segment_identifier template inline typename sub_range_return_type::type sub_range(Geometry & geometry, Id const& id) { return detail_dispatch::sub_range::apply(geometry, id); } } // namespace detail #endif // DOXYGEN_NO_DETAIL }} // namespace boost::geometry #endif // BOOST_GEOMETRY_ALGORITHMS_DETAIL_SUB_RANGE_HPP