// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2014 Samuel Debionne, Grenoble, France. // 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_UTIL_COMBINE_IF_HPP #define BOOST_GEOMETRY_UTIL_COMBINE_IF_HPP #include #include #include #include #include #include #include namespace boost { namespace geometry { namespace util { /*! \brief Meta-function to generate all the combination of pairs of types from a given sequence Sequence except those that does not satisfy the predicate Pred \ingroup utility \par Example \code typedef mpl::vector, mpl::int_<1> > types; typedef combine_if >::type combinations; typedef mpl::vector< pair, mpl::int_<1> >, pair, mpl::int_<0> >, pair, mpl::int_<1> >, pair, mpl::int_<0> > > result_types; BOOST_MPL_ASSERT(( mpl::equal )); \endcode */ template struct combine_if { struct combine { template struct apply { typedef typename mpl::fold::type, T, mpl::_2>, mpl::insert >, mpl::_1 > >::type type; }; }; typedef typename mpl::fold, combine>::type type; }; } // namespace util }} // namespace boost::geometry #endif // BOOST_GEOMETRY_UTIL_COMBINE_IF_HPP