// graph-tool -- a general graph modification and manipulation thingy // // Copyright (C) 2007-2012 Tiago de Paula Peixoto // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License // as published by the Free Software Foundation; either version 3 // of the License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . #include "graph.hh" #include "graph_filtering.hh" #include "graph_union.hh" #include #include using namespace graph_tool; using namespace boost; typedef property_map_type::apply::type vprop_t; typedef property_map_type::apply::type eprop_t; struct get_pointers { template struct apply { typedef typename mpl::transform >::type type; }; }; void edge_property_union(GraphInterface& ugi, GraphInterface& gi, boost::any p_vprop, boost::any p_eprop, boost::any uprop, boost::any prop) { vprop_t vprop = any_cast(p_vprop); eprop_t eprop = any_cast(p_eprop); run_action() (ugi, bind(graph_tool::property_union(), _1, _2, vprop, eprop, _3, prop), get_pointers::apply::type(), writable_edge_properties()) (gi.GetGraphView(), uprop); }