12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004 |
- //=======================================================================
- // 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 <functional>
- #include <vector>
- #include <boost/limits.hpp>
- #include <boost/core/enable_if.hpp>
- #include <boost/core/ref.hpp>
- #include <boost/utility/result_of.hpp>
- #include <boost/preprocessor.hpp>
- #include <boost/parameter/is_argument_pack.hpp>
- #include <boost/parameter/name.hpp>
- #include <boost/parameter/binding.hpp>
- #include <boost/type_traits.hpp>
- #include <boost/mpl/bool.hpp>
- #include <boost/mpl/has_key.hpp>
- #include <boost/graph/properties.hpp>
- #include <boost/graph/detail/d_ary_heap.hpp>
- #include <boost/property_map/property_map.hpp>
- #include <boost/property_map/shared_array_property_map.hpp>
- 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
|