//======================================================================= // Copyright 1997, 1998, 1999, 2000 University of Notre Dame. // Authors: Andrew Lumsdaine, Lie-Quan Lee, Jeremy G. Siek // // Distributed under 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_GRAPH_NAMED_FUNCTION_PARAMS_HPP #define BOOST_GRAPH_NAMED_FUNCTION_PARAMS_HPP #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { struct parity_map_t { }; struct vertex_assignment_map_t { }; struct distance_compare_t { }; struct distance_combine_t { }; struct distance_inf_t { }; struct distance_zero_t { }; struct buffer_param_t { }; struct edge_copy_t { }; struct vertex_copy_t { }; struct vertex_isomorphism_t { }; struct vertex_invariant_t { }; struct vertex_invariant1_t { }; struct vertex_invariant2_t { }; struct edge_compare_t { }; struct vertex_max_invariant_t { }; struct orig_to_copy_t { }; struct root_vertex_t { }; struct polling_t { }; struct lookahead_t { }; struct in_parallel_t { }; struct attractive_force_t { }; struct repulsive_force_t { }; struct force_pairs_t { }; struct cooling_t { }; struct vertex_displacement_t { }; struct iterations_t { }; struct diameter_range_t { }; struct learning_constant_range_t { }; struct vertices_equivalent_t { }; struct edges_equivalent_t { }; struct index_in_heap_map_t { }; struct max_priority_queue_t { }; #define BOOST_BGL_DECLARE_NAMED_PARAMS \ BOOST_BGL_ONE_PARAM_CREF(weight_map, edge_weight) \ BOOST_BGL_ONE_PARAM_CREF(weight_map2, edge_weight2) \ BOOST_BGL_ONE_PARAM_CREF(distance_map, vertex_distance) \ BOOST_BGL_ONE_PARAM_CREF(distance_map2, vertex_distance2) \ BOOST_BGL_ONE_PARAM_CREF(predecessor_map, vertex_predecessor) \ BOOST_BGL_ONE_PARAM_CREF(rank_map, vertex_rank) \ BOOST_BGL_ONE_PARAM_CREF(root_map, vertex_root) \ BOOST_BGL_ONE_PARAM_CREF(root_vertex, root_vertex) \ BOOST_BGL_ONE_PARAM_CREF(edge_centrality_map, edge_centrality) \ BOOST_BGL_ONE_PARAM_CREF(centrality_map, vertex_centrality) \ BOOST_BGL_ONE_PARAM_CREF(parity_map, parity_map) \ BOOST_BGL_ONE_PARAM_CREF(color_map, vertex_color) \ BOOST_BGL_ONE_PARAM_CREF(edge_color_map, edge_color) \ BOOST_BGL_ONE_PARAM_CREF(capacity_map, edge_capacity) \ BOOST_BGL_ONE_PARAM_CREF(residual_capacity_map, edge_residual_capacity) \ BOOST_BGL_ONE_PARAM_CREF(reverse_edge_map, edge_reverse) \ BOOST_BGL_ONE_PARAM_CREF(discover_time_map, vertex_discover_time) \ BOOST_BGL_ONE_PARAM_CREF(lowpoint_map, vertex_lowpoint) \ BOOST_BGL_ONE_PARAM_CREF(vertex_index_map, vertex_index) \ BOOST_BGL_ONE_PARAM_CREF(vertex_index1_map, vertex_index1) \ BOOST_BGL_ONE_PARAM_CREF(vertex_index2_map, vertex_index2) \ BOOST_BGL_ONE_PARAM_CREF(vertex_assignment_map, vertex_assignment_map) \ BOOST_BGL_ONE_PARAM_CREF(visitor, graph_visitor) \ BOOST_BGL_ONE_PARAM_CREF(distance_compare, distance_compare) \ BOOST_BGL_ONE_PARAM_CREF(distance_combine, distance_combine) \ BOOST_BGL_ONE_PARAM_CREF(distance_inf, distance_inf) \ BOOST_BGL_ONE_PARAM_CREF(distance_zero, distance_zero) \ BOOST_BGL_ONE_PARAM_CREF(edge_copy, edge_copy) \ BOOST_BGL_ONE_PARAM_CREF(vertex_copy, vertex_copy) \ BOOST_BGL_ONE_PARAM_REF(buffer, buffer_param) \ BOOST_BGL_ONE_PARAM_CREF(orig_to_copy, orig_to_copy) \ BOOST_BGL_ONE_PARAM_CREF(isomorphism_map, vertex_isomorphism) \ BOOST_BGL_ONE_PARAM_CREF(vertex_invariant, vertex_invariant) \ BOOST_BGL_ONE_PARAM_CREF(vertex_invariant1, vertex_invariant1) \ BOOST_BGL_ONE_PARAM_CREF(vertex_invariant2, vertex_invariant2) \ BOOST_BGL_ONE_PARAM_CREF(vertex_max_invariant, vertex_max_invariant) \ BOOST_BGL_ONE_PARAM_CREF(polling, polling) \ BOOST_BGL_ONE_PARAM_CREF(lookahead, lookahead) \ BOOST_BGL_ONE_PARAM_CREF(in_parallel, in_parallel) \ BOOST_BGL_ONE_PARAM_CREF(displacement_map, vertex_displacement) \ BOOST_BGL_ONE_PARAM_CREF(attractive_force, attractive_force) \ BOOST_BGL_ONE_PARAM_CREF(repulsive_force, repulsive_force) \ BOOST_BGL_ONE_PARAM_CREF(force_pairs, force_pairs) \ BOOST_BGL_ONE_PARAM_CREF(cooling, cooling) \ BOOST_BGL_ONE_PARAM_CREF(iterations, iterations) \ BOOST_BGL_ONE_PARAM_CREF(diameter_range, diameter_range) \ BOOST_BGL_ONE_PARAM_CREF(learning_constant_range, learning_constant_range) \ BOOST_BGL_ONE_PARAM_CREF(vertices_equivalent, vertices_equivalent) \ BOOST_BGL_ONE_PARAM_CREF(edges_equivalent, edges_equivalent) \ BOOST_BGL_ONE_PARAM_CREF(index_in_heap_map, index_in_heap_map) \ BOOST_BGL_ONE_PARAM_REF(max_priority_queue, max_priority_queue) template < typename T, typename Tag, typename Base = no_property > struct bgl_named_params { typedef bgl_named_params self; typedef Base next_type; typedef Tag tag_type; typedef T value_type; bgl_named_params(T v = T()) : m_value(v) {} bgl_named_params(T v, const Base& b) : m_value(v), m_base(b) {} T m_value; Base m_base; #define BOOST_BGL_ONE_PARAM_REF(name, key) \ template < typename PType > \ bgl_named_params< boost::reference_wrapper< PType >, \ BOOST_PP_CAT(key, _t), self > \ name(PType& p) const \ { \ typedef bgl_named_params< boost::reference_wrapper< PType >, \ BOOST_PP_CAT(key, _t), self > \ Params; \ return Params(boost::ref(p), *this); \ } #define BOOST_BGL_ONE_PARAM_CREF(name, key) \ template < typename PType > \ bgl_named_params< PType, BOOST_PP_CAT(key, _t), self > name( \ const PType& p) const \ { \ typedef bgl_named_params< PType, BOOST_PP_CAT(key, _t), self > Params; \ return Params(p, *this); \ } BOOST_BGL_DECLARE_NAMED_PARAMS #undef BOOST_BGL_ONE_PARAM_REF #undef BOOST_BGL_ONE_PARAM_CREF // Duplicate template < typename PType > bgl_named_params< PType, vertex_color_t, self > vertex_color_map( const PType& p) const { return this->color_map(p); } }; #define BOOST_BGL_ONE_PARAM_REF(name, key) \ template < typename PType > \ bgl_named_params< boost::reference_wrapper< PType >, \ BOOST_PP_CAT(key, _t) > \ name(PType& p) \ { \ typedef bgl_named_params< boost::reference_wrapper< PType >, \ BOOST_PP_CAT(key, _t) > \ Params; \ return Params(boost::ref(p)); \ } #define BOOST_BGL_ONE_PARAM_CREF(name, key) \ template < typename PType > \ bgl_named_params< PType, BOOST_PP_CAT(key, _t) > name(const PType& p) \ { \ typedef bgl_named_params< PType, BOOST_PP_CAT(key, _t) > Params; \ return Params(p); \ } BOOST_BGL_DECLARE_NAMED_PARAMS #undef BOOST_BGL_ONE_PARAM_REF #undef BOOST_BGL_ONE_PARAM_CREF // Duplicate template < typename PType > bgl_named_params< PType, vertex_color_t > vertex_color_map(const PType& p) { return color_map(p); } namespace detail { struct unused_tag_type { }; } typedef bgl_named_params< char, detail::unused_tag_type > no_named_parameters; //=========================================================================== // Functions for extracting parameters from bgl_named_params template < typename Tag, typename Args > struct lookup_named_param { }; template < typename T, typename Tag, typename Base > struct lookup_named_param< Tag, bgl_named_params< T, Tag, Base > > { typedef T type; static const T& get(const bgl_named_params< T, Tag, Base >& p) { return p.m_value; } }; template < typename Tag1, typename T, typename Tag, typename Base > struct lookup_named_param< Tag1, bgl_named_params< T, Tag, Base > > { typedef typename lookup_named_param< Tag1, Base >::type type; static const type& get(const bgl_named_params< T, Tag, Base >& p) { return lookup_named_param< Tag1, Base >::get(p.m_base); } }; template < typename Tag, typename Args, typename Def > struct lookup_named_param_def { typedef Def type; static const Def& get(const Args&, const Def& def) { return def; } }; template < typename T, typename Tag, typename Base, typename Def > struct lookup_named_param_def< Tag, bgl_named_params< T, Tag, Base >, Def > { typedef T type; static const type& get( const bgl_named_params< T, Tag, Base >& p, const Def&) { return p.m_value; } }; template < typename Tag1, typename T, typename Tag, typename Base, typename Def > struct lookup_named_param_def< Tag1, bgl_named_params< T, Tag, Base >, Def > { typedef typename lookup_named_param_def< Tag1, Base, Def >::type type; static const type& get( const bgl_named_params< T, Tag, Base >& p, const Def& def) { return lookup_named_param_def< Tag1, Base, Def >::get(p.m_base, def); } }; struct param_not_found { }; static param_not_found g_param_not_found; template < typename Tag, typename Args > struct get_param_type : lookup_named_param_def< Tag, Args, param_not_found > { }; template < class Tag, typename Args > inline const typename lookup_named_param_def< Tag, Args, param_not_found >::type& get_param(const Args& p, Tag) { return lookup_named_param_def< Tag, Args, param_not_found >::get( p, g_param_not_found); } template < class P, class Default > const P& choose_param(const P& param, const Default&) { return param; } template < class Default > Default choose_param(const param_not_found&, const Default& d) { return d; } template < typename T > inline bool is_default_param(const T&) { return false; } inline bool is_default_param(const param_not_found&) { return true; } namespace detail { template < typename T > struct const_type_as_type { typedef typename T::const_type type; }; } // namespace detail // Use this function instead of choose_param() when you want // to avoid requiring get(tag, g) when it is not used. namespace detail { template < typename GraphIsConst, typename Graph, typename Param, typename Tag > struct choose_impl_result : boost::mpl::eval_if< boost::is_same< Param, param_not_found >, boost::mpl::eval_if< GraphIsConst, detail::const_type_as_type< property_map< Graph, Tag > >, property_map< Graph, Tag > >, boost::mpl::identity< Param > > { }; // Parameters of f are (GraphIsConst, Graph, Param, Tag) template < bool Found > struct choose_impl_helper; template <> struct choose_impl_helper< false > { template < typename Param, typename Graph, typename PropertyTag > static typename property_map< typename boost::remove_const< Graph >::type, PropertyTag >::const_type f(boost::mpl::true_, const Graph& g, const Param&, PropertyTag tag) { return get(tag, g); } template < typename Param, typename Graph, typename PropertyTag > static typename property_map< typename boost::remove_const< Graph >::type, PropertyTag >::type f(boost::mpl::false_, Graph& g, const Param&, PropertyTag tag) { return get(tag, g); } }; template <> struct choose_impl_helper< true > { template < typename GraphIsConst, typename Param, typename Graph, typename PropertyTag > static Param f(GraphIsConst, const Graph&, const Param& p, PropertyTag) { return p; } }; } template < typename Param, typename Graph, typename PropertyTag > typename detail::choose_impl_result< boost::mpl::true_, Graph, Param, PropertyTag >::type choose_const_pmap(const Param& p, const Graph& g, PropertyTag tag) { return detail::choose_impl_helper< !boost::is_same< Param, param_not_found >::value >::f(boost::mpl::true_(), g, p, tag); } template < typename Param, typename Graph, typename PropertyTag > typename detail::choose_impl_result< boost::mpl::false_, Graph, Param, PropertyTag >::type choose_pmap(const Param& p, Graph& g, PropertyTag tag) { return detail::choose_impl_helper< !boost::is_same< Param, param_not_found >::value >::f(boost::mpl::false_(), g, p, tag); } namespace detail { // used in the max-flow algorithms template < class Graph, class P, class T, class R > struct edge_capacity_value { typedef bgl_named_params< P, T, R > Params; typedef typename detail::choose_impl_result< boost::mpl::true_, Graph, typename get_param_type< edge_capacity_t, Params >::type, edge_capacity_t >::type CapacityEdgeMap; typedef typename property_traits< CapacityEdgeMap >::value_type type; }; // used in the max-flow algorithms template < class Graph, class P, class T, class R > struct edge_weight_value { typedef bgl_named_params< P, T, R > Params; typedef typename detail::choose_impl_result< boost::mpl::true_, Graph, typename get_param_type< edge_weight_t, Params >::type, edge_weight_t >::type WeightMap; typedef typename property_traits< WeightMap >::value_type type; }; } // Declare all new tags namespace graph { namespace keywords { #define BOOST_BGL_ONE_PARAM_REF(name, key) BOOST_PARAMETER_NAME(name) #define BOOST_BGL_ONE_PARAM_CREF(name, key) BOOST_PARAMETER_NAME(name) BOOST_BGL_DECLARE_NAMED_PARAMS #undef BOOST_BGL_ONE_PARAM_REF #undef BOOST_BGL_ONE_PARAM_CREF } } namespace detail { template < typename Tag > struct convert_one_keyword { }; #define BOOST_BGL_ONE_PARAM_REF(name, key) \ template <> struct convert_one_keyword< BOOST_PP_CAT(key, _t) > \ { \ typedef boost::graph::keywords::tag::name type; \ }; #define BOOST_BGL_ONE_PARAM_CREF(name, key) BOOST_BGL_ONE_PARAM_REF(name, key) BOOST_BGL_DECLARE_NAMED_PARAMS #undef BOOST_BGL_ONE_PARAM_REF #undef BOOST_BGL_ONE_PARAM_CREF template < typename T > struct convert_bgl_params_to_boost_parameter { typedef typename convert_one_keyword< typename T::tag_type >::type new_kw; typedef boost::parameter::aux::tagged_argument< new_kw, const typename T::value_type > tagged_arg_type; typedef convert_bgl_params_to_boost_parameter< typename T::next_type > rest_conv; typedef boost::parameter::aux::arg_list< tagged_arg_type, typename rest_conv::type > type; static type conv(const T& x) { return type(tagged_arg_type(x.m_value), rest_conv::conv(x.m_base)); } }; template < typename P, typename R > struct convert_bgl_params_to_boost_parameter< bgl_named_params< P, int, R > > { typedef convert_bgl_params_to_boost_parameter< R > rest_conv; typedef typename rest_conv::type type; static type conv(const bgl_named_params< P, int, R >& x) { return rest_conv::conv(x.m_base); } }; template <> struct convert_bgl_params_to_boost_parameter< boost::no_property > { typedef boost::parameter::aux::empty_arg_list type; static type conv(const boost::no_property&) { return type(); } }; template <> struct convert_bgl_params_to_boost_parameter< boost::no_named_parameters > { typedef boost::parameter::aux::empty_arg_list type; static type conv(const boost::no_named_parameters&) { return type(); } }; struct bgl_parameter_not_found_type { }; } #define BOOST_GRAPH_DECLARE_CONVERTED_PARAMETERS(old_type, old_var) \ typedef typename boost::detail::convert_bgl_params_to_boost_parameter< \ old_type >::type arg_pack_type; \ arg_pack_type arg_pack \ = boost::detail::convert_bgl_params_to_boost_parameter< \ old_type >::conv(old_var); namespace detail { template < typename ArgType, typename Prop, typename Graph, bool Exists > struct override_const_property_t { typedef typename boost::remove_const< ArgType >::type result_type; result_type operator()(const Graph&, const ArgType& a) const { return a; } }; template < typename ArgType, typename Prop, typename Graph > struct override_const_property_t< ArgType, Prop, Graph, false > { typedef typename boost::property_map< Graph, Prop >::const_type result_type; result_type operator()(const Graph& g, const ArgType&) const { return get(Prop(), g); } }; template < typename ArgPack, typename Tag, typename Prop, typename Graph > struct override_const_property_result { typedef typename boost::mpl::has_key< ArgPack, Tag >::type _parameter_exists; typedef typename override_const_property_t< typename boost::parameter::value_type< ArgPack, Tag, int >::type, Prop, Graph, _parameter_exists::value >::result_type type; }; template < typename ArgPack, typename Tag, typename Prop, typename Graph > typename override_const_property_result< ArgPack, Tag, Prop, Graph >::type override_const_property(const ArgPack& ap, const boost::parameter::keyword< Tag >& t, const Graph& g, Prop) { typedef typename boost::mpl::has_key< ArgPack, Tag >::type _parameter_exists; return override_const_property_t< typename boost::parameter::value_type< ArgPack, Tag, int >::type, Prop, Graph, _parameter_exists::value >()(g, ap[t | 0]); } template < typename ArgType, typename Prop, typename Graph, bool Exists > struct override_property_t { typedef ArgType result_type; result_type operator()(const Graph&, typename boost::add_lvalue_reference< ArgType >::type a) const { return a; } }; template < typename ArgType, typename Prop, typename Graph > struct override_property_t< ArgType, Prop, Graph, false > { typedef typename boost::property_map< Graph, Prop >::type result_type; result_type operator()(const Graph& g, const ArgType&) const { return get(Prop(), g); } }; template < typename ArgPack, typename Tag, typename Prop, typename Graph > struct override_property_result { typedef typename boost::mpl::has_key< ArgPack, Tag >::type _parameter_exists; typedef typename override_property_t< typename boost::parameter::value_type< ArgPack, Tag, int >::type, Prop, Graph, _parameter_exists::value >::result_type type; }; template < typename ArgPack, typename Tag, typename Prop, typename Graph > typename override_property_result< ArgPack, Tag, Prop, Graph >::type override_property(const ArgPack& ap, const boost::parameter::keyword< Tag >& t, const Graph& g, Prop) { typedef typename boost::mpl::has_key< ArgPack, Tag >::type _parameter_exists; return override_property_t< typename boost::parameter::value_type< ArgPack, Tag, int >::type, Prop, Graph, _parameter_exists::value >()(g, ap[t | 0]); } template < typename F > struct make_arg_pack_type; template <> struct make_arg_pack_type< void() > { typedef boost::parameter::aux::empty_arg_list type; }; template < typename K, typename A > struct make_arg_pack_type< void(K, A) > { typedef boost::parameter::aux::tagged_argument< K, A > type; }; #define BOOST_GRAPH_OPENING_PART_OF_PAIR(z, i, n) \ boost::parameter::aux::arg_list \ < boost::parameter::aux::tagged_argument< BOOST_PP_CAT(Keyword, \ BOOST_PP_SUB(n, i)), \ BOOST_PP_CAT(Arg, BOOST_PP_SUB(n, i)) >, #define BOOST_GRAPH_MAKE_PAIR_PARAM(z, i, _) \ const boost::parameter::aux::tagged_argument< BOOST_PP_CAT(Keyword, i), \ BOOST_PP_CAT(Arg, i) >& BOOST_PP_CAT(kw, i) #define BOOST_GRAPH_MAKE_AP_TYPE_SPECIALIZATION(z, i, _) \ template < BOOST_PP_ENUM_PARAMS(i, typename Keyword), \ BOOST_PP_ENUM_PARAMS(i, typename Arg) > \ struct make_arg_pack_type< void( \ BOOST_PP_ENUM_PARAMS(i, Keyword), BOOST_PP_ENUM_PARAMS(i, Arg)) > \ { \ typedef BOOST_PP_REPEAT(i, BOOST_GRAPH_OPENING_PART_OF_PAIR, \ BOOST_PP_DEC(i)) boost::parameter::aux::empty_arg_list \ BOOST_PP_REPEAT(i, > BOOST_PP_TUPLE_EAT(3), ~) type; \ }; BOOST_PP_REPEAT_FROM_TO(2, 11, BOOST_GRAPH_MAKE_AP_TYPE_SPECIALIZATION, ~) #undef BOOST_GRAPH_MAKE_AP_TYPE_SPECIALIZATION #define BOOST_GRAPH_MAKE_FORWARDING_FUNCTION(name, nfixed, nnamed_max) \ /* Entry point for conversion from BGL-style named parameters */ \ template < BOOST_PP_ENUM_PARAMS(nfixed, typename Param) \ BOOST_PP_COMMA_IF(nfixed) typename ArgPack > \ typename boost::result_of< detail::BOOST_PP_CAT(name, _impl) \ < BOOST_PP_ENUM_PARAMS(nfixed, Param) >(BOOST_PP_ENUM_PARAMS( \ nfixed, Param) BOOST_PP_COMMA_IF(nfixed) const ArgPack&) \ > ::type BOOST_PP_CAT(name, _with_named_params)( \ BOOST_PP_ENUM_BINARY_PARAMS(nfixed, const Param, ¶m) \ BOOST_PP_COMMA_IF(nfixed) const ArgPack& arg_pack) \ { \ return detail::BOOST_PP_CAT( \ name, _impl)< BOOST_PP_ENUM_PARAMS(nfixed, Param) >()( \ BOOST_PP_ENUM_PARAMS(nfixed, param) BOOST_PP_COMMA_IF(nfixed) \ arg_pack); \ } \ /* Individual functions taking Boost.Parameter-style keyword arguments */ \ BOOST_PP_REPEAT(BOOST_PP_INC(nnamed_max), \ BOOST_GRAPH_MAKE_FORWARDING_FUNCTION_ONE, (name)(nfixed)) #define BOOST_GRAPH_MAKE_FORWARDING_FUNCTION_ONE(z, nnamed, seq) \ BOOST_GRAPH_MAKE_FORWARDING_FUNCTION_ONEX( \ z, nnamed, BOOST_PP_SEQ_ELEM(0, seq), BOOST_PP_SEQ_ELEM(1, seq)) #define BOOST_GRAPH_MAKE_FORWARDING_FUNCTION_ONEX(z, nnamed, name, nfixed) \ template < BOOST_PP_ENUM_PARAMS_Z(z, nfixed, typename Param) \ BOOST_PP_ENUM_TRAILING_PARAMS_Z( \ z, nnamed, typename ArgumentPack) > \ typename BOOST_PP_EXPR_IF(nnamed, \ boost::lazy_enable_if \ < boost::parameter::is_argument_pack< ArgumentPack0 >) \ BOOST_PP_COMMA_IF(nnamed)::boost::graph::detail::BOOST_PP_CAT( \ name, _impl)< BOOST_PP_ENUM_PARAMS_Z(z, nfixed, Param) > \ BOOST_PP_EXPR_IF(nnamed, >)::type name( \ BOOST_PP_ENUM_BINARY_PARAMS_Z(z, nfixed, Param, const& param) \ BOOST_PP_ENUM_TRAILING_BINARY_PARAMS_Z( \ z, nnamed, ArgumentPack, const& tagged_arg)) \ { \ return ::boost::graph::BOOST_PP_CAT(name, _with_named_params)( \ BOOST_PP_ENUM_PARAMS_Z(z, nfixed, param) BOOST_PP_COMMA_IF(nnamed) \ BOOST_PP_LPAREN_IF(nnamed) BOOST_PP_ENUM_PARAMS_Z( \ z, nnamed, tagged_arg) BOOST_PP_RPAREN_IF(nnamed)); \ } #define BOOST_GRAPH_MAKE_OLD_STYLE_PARAMETER_FUNCTION(name, nfixed) \ template < BOOST_PP_ENUM_PARAMS(nfixed, typename Param) \ BOOST_PP_COMMA_IF(nfixed) class P, \ class T, class R > \ typename boost::result_of< ::boost::graph::detail::BOOST_PP_CAT( \ name, _impl) BOOST_PP_EXPR_IF(nfixed, <) BOOST_PP_ENUM_PARAMS(nfixed, \ Param) BOOST_PP_EXPR_IF(nfixed, >)(BOOST_PP_ENUM_PARAMS(nfixed, Param) \ BOOST_PP_COMMA_IF(nfixed) const typename boost::detail:: \ convert_bgl_params_to_boost_parameter< \ boost::bgl_named_params< P, T, R > >::type&) >::type \ name(BOOST_PP_ENUM_BINARY_PARAMS(nfixed, const Param, ¶m) \ BOOST_PP_COMMA_IF(nfixed) \ const boost::bgl_named_params< P, T, R >& old_style_params) \ { \ typedef boost::bgl_named_params< P, T, R > old_style_params_type; \ BOOST_GRAPH_DECLARE_CONVERTED_PARAMETERS( \ old_style_params_type, old_style_params) \ return ::boost::graph::BOOST_PP_CAT(name, _with_named_params)( \ BOOST_PP_ENUM_PARAMS(nfixed, param) BOOST_PP_COMMA_IF(nfixed) \ arg_pack); \ } \ BOOST_PP_EXPR_IF(nfixed, template < ) \ BOOST_PP_ENUM_PARAMS(nfixed, typename Param) \ BOOST_PP_EXPR_IF(nfixed, >) \ BOOST_PP_EXPR_IF(nfixed, typename) \ boost::result_of< ::boost::graph::detail::BOOST_PP_CAT( \ name, _impl) BOOST_PP_EXPR_IF(nfixed, \ <) BOOST_PP_ENUM_PARAMS(nfixed, Param) BOOST_PP_EXPR_IF(nfixed, \ >)(BOOST_PP_ENUM_PARAMS(nfixed, Param) BOOST_PP_COMMA_IF(nfixed) \ const boost::parameter::aux::empty_arg_list&) >::type \ name(BOOST_PP_ENUM_BINARY_PARAMS(nfixed, const Param, ¶m)) \ { \ BOOST_GRAPH_DECLARE_CONVERTED_PARAMETERS( \ boost::no_named_parameters, boost::no_named_parameters()) \ return ::boost::graph::BOOST_PP_CAT(name, _with_named_params)( \ BOOST_PP_ENUM_PARAMS(nfixed, param) BOOST_PP_COMMA_IF(nfixed) \ arg_pack); \ } } namespace detail { template < bool Exists, typename Graph, typename ArgPack, typename Value, typename PM > struct map_maker_helper { typedef PM map_type; static PM make_map(const Graph&, Value, const PM& pm, const ArgPack&) { return pm; } }; template < typename Graph, typename ArgPack, typename Value, typename PM > struct map_maker_helper< false, Graph, ArgPack, Value, PM > { typedef typename boost::mpl::has_key< ArgPack, boost::graph::keywords::tag::vertex_index_map >::type _parameter_exists; typedef typename boost::remove_const< typename override_const_property_t< typename boost::parameter::value_type< ArgPack, boost::graph::keywords::tag::vertex_index_map, int >::type, boost::vertex_index_t, Graph, _parameter_exists::value >::result_type >::type vi_map_type; typedef boost::shared_array_property_map< Value, vi_map_type > map_type; static map_type make_map( const Graph& g, Value v, const PM&, const ArgPack& ap) { return make_shared_array_property_map(num_vertices(g), v, override_const_property(ap, boost::graph::keywords::_vertex_index_map, g, vertex_index)); } }; template < typename Graph, typename ArgPack, typename MapTag, typename ValueType > struct map_maker { typedef typename boost::mpl::has_key< ArgPack, MapTag >::type _parameter_exists; BOOST_STATIC_CONSTANT(bool, has_map = (_parameter_exists::value)); typedef map_maker_helper< has_map, Graph, ArgPack, ValueType, typename boost::remove_const< typename boost::parameter::value_type< ArgPack, MapTag, int >::type >::type > helper; typedef typename helper::map_type map_type; static map_type make_map( const Graph& g, const ArgPack& ap, ValueType default_value) { return helper::make_map(g, default_value, ap[::boost::parameter::keyword< MapTag >::instance | 0], ap); } }; template < typename MapTag, typename ValueType = void > class make_property_map_from_arg_pack_gen { ValueType default_value; public: make_property_map_from_arg_pack_gen(ValueType default_value) : default_value(default_value) { } template < typename Graph, typename ArgPack > typename map_maker< Graph, ArgPack, MapTag, ValueType >::map_type operator()(const Graph& g, const ArgPack& ap) const { return map_maker< Graph, ArgPack, MapTag, ValueType >::make_map( g, ap, default_value); } }; template < typename MapTag > class make_property_map_from_arg_pack_gen< MapTag, void > { public: template < typename ValueType, typename Graph, typename ArgPack > typename map_maker< Graph, ArgPack, MapTag, ValueType >::map_type operator()( const Graph& g, const ArgPack& ap, ValueType default_value) const { return map_maker< Graph, ArgPack, MapTag, ValueType >::make_map( g, ap, default_value); } }; static const make_property_map_from_arg_pack_gen< boost::graph::keywords::tag::color_map, default_color_type > make_color_map_from_arg_pack(white_color); template < bool Exists, class Graph, class ArgPack, class KeyT, class ValueT, class KeyMapTag, class IndexInHeapMapTag, class Compare, class Q > struct priority_queue_maker_helper { typedef Q priority_queue_type; static priority_queue_type make_queue( const Graph&, const ArgPack&, KeyT, const Q& q) { return q; } }; template < class Graph, class ArgPack, class KeyT, class ValueT, class KeyMapTag, class IndexInHeapMapTag, class Compare, class Q > struct priority_queue_maker_helper< false, Graph, ArgPack, KeyT, ValueT, KeyMapTag, IndexInHeapMapTag, Compare, Q > { typedef typename std::vector< ValueT >::size_type default_index_in_heap_type; typedef typename map_maker< Graph, ArgPack, IndexInHeapMapTag, default_index_in_heap_type >::helper::map_type index_in_heap_map; typedef boost::d_ary_heap_indirect< ValueT, 4, index_in_heap_map, typename map_maker< Graph, ArgPack, KeyMapTag, KeyT >::helper::map_type, Compare > priority_queue_type; static priority_queue_type make_queue( const Graph& g, const ArgPack& ap, KeyT defaultKey, const Q&) { return priority_queue_type( map_maker< Graph, ArgPack, KeyMapTag, KeyT >::make_map( g, ap, defaultKey), map_maker< Graph, ArgPack, IndexInHeapMapTag, default_index_in_heap_type >::make_map(g, ap, typename boost::property_traits< index_in_heap_map >::value_type(-1))); } }; template < class Graph, class ArgPack, class KeyT, class ValueT, class PriorityQueueTag, class KeyMapTag, class IndexInHeapMapTag, class Compare > struct priority_queue_maker { typedef typename boost::mpl::has_key< ArgPack, PriorityQueueTag >::type _parameter_exists; BOOST_STATIC_CONSTANT(bool, g_hasQ = (_parameter_exists::value)); typedef boost::reference_wrapper< int > int_refw; typedef typename boost::parameter::value_type< ArgPack, PriorityQueueTag, int_refw >::type param_value_type_wrapper; typedef typename param_value_type_wrapper::type param_value_type; typedef typename boost::remove_const< param_value_type >::type param_value_type_no_const; typedef priority_queue_maker_helper< g_hasQ, Graph, ArgPack, KeyT, ValueT, KeyMapTag, IndexInHeapMapTag, Compare, param_value_type_no_const > helper; typedef typename helper::priority_queue_type priority_queue_type; static priority_queue_type make_queue( const Graph& g, const ArgPack& ap, KeyT defaultKey) { return helper::make_queue(g, ap, defaultKey, ap[::boost::parameter::keyword< PriorityQueueTag >::instance | 0]); } }; template < class PriorityQueueTag, class KeyT, class ValueT, class Compare = std::less< KeyT >, class KeyMapTag = boost::graph::keywords::tag::distance_map, class IndexInHeapMapTag = boost::graph::keywords::tag::index_in_heap_map > struct make_priority_queue_from_arg_pack_gen { KeyT defaultKey; make_priority_queue_from_arg_pack_gen(KeyT defaultKey_) : defaultKey(defaultKey_) { } template < class F > struct result { typedef typename remove_const< typename remove_reference< typename function_traits< F >::arg1_type >::type >::type graph_type; typedef typename remove_const< typename remove_reference< typename function_traits< F >::arg2_type >::type >::type arg_pack_type; typedef typename priority_queue_maker< graph_type, arg_pack_type, KeyT, ValueT, PriorityQueueTag, KeyMapTag, IndexInHeapMapTag, Compare >::priority_queue_type type; }; template < class Graph, class ArgPack > typename priority_queue_maker< Graph, ArgPack, KeyT, ValueT, PriorityQueueTag, KeyMapTag, IndexInHeapMapTag, Compare >::priority_queue_type operator()(const Graph& g, const ArgPack& ap) const { return priority_queue_maker< Graph, ArgPack, KeyT, ValueT, PriorityQueueTag, KeyMapTag, IndexInHeapMapTag, Compare >::make_queue(g, ap, defaultKey); } }; template < typename G > typename boost::graph_traits< G >::vertex_descriptor get_null_vertex( const G&) { return boost::graph_traits< G >::null_vertex(); } template < typename G > typename boost::graph_traits< G >::vertex_descriptor get_default_starting_vertex(const G& g) { std::pair< typename boost::graph_traits< G >::vertex_iterator, typename boost::graph_traits< G >::vertex_iterator > iters = vertices(g); return (iters.first == iters.second) ? boost::graph_traits< G >::null_vertex() : *iters.first; } template < typename G > struct get_default_starting_vertex_t { typedef typename boost::graph_traits< G >::vertex_descriptor result_type; const G& g; get_default_starting_vertex_t(const G& g) : g(g) {} result_type operator()() const { return get_default_starting_vertex(g); } }; // Wrapper to avoid instantiating numeric_limits when users provide // distance_inf value manually template < typename T > struct get_max { T operator()() const { return (std::numeric_limits< T >::max)(); } typedef T result_type; }; } // namespace detail } // namespace boost #undef BOOST_BGL_DECLARE_NAMED_PARAMS #endif // BOOST_GRAPH_NAMED_FUNCTION_PARAMS_HPP