// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2007-2011 Barend Gehrels, Amsterdam, the Netherlands. // Copyright (c) 2008-2011 Bruno Lalande, Paris, France. // Copyright (c) 2009-2011 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. // 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_FOR_EACH_RANGE_HPP #define BOOST_GEOMETRY_ALGORITHMS_DETAIL_FOR_EACH_RANGE_HPP #include #include #include #include namespace boost { namespace geometry { #ifndef DOXYGEN_NO_DETAIL namespace detail { namespace for_each { template struct fe_range_range { static inline void apply( typename add_const_if_c::type& range, Actor& actor) { actor.apply(range); } }; template struct fe_range_polygon { static inline void apply( typename add_const_if_c::type& polygon, Actor& actor) { actor.apply(exterior_ring(polygon)); // TODO: If some flag says true, also do the inner rings. // for convex hull, it's not necessary } }; }} // namespace detail::for_each #endif // DOXYGEN_NO_DETAIL #ifndef DOXYGEN_NO_DISPATCH namespace dispatch { template < typename Tag, typename Geometry, typename Actor, bool IsConst > struct for_each_range {}; template struct for_each_range : detail::for_each::fe_range_range {}; template struct for_each_range : detail::for_each::fe_range_range {}; template struct for_each_range : detail::for_each::fe_range_polygon {}; } // namespace dispatch #endif // DOXYGEN_NO_DISPATCH namespace detail { template inline void for_each_range(Geometry const& geometry, Actor& actor) { dispatch::for_each_range < typename tag::type, Geometry, Actor, true >::apply(geometry, actor); } } }} // namespace boost::geometry #endif // BOOST_GEOMETRY_ALGORITHMS_DETAIL_FOR_EACH_RANGE_HPP