-RoutedZone::RoutedZone(NetZoneImpl* father, std::string name) : NetZoneImpl(father, name) {}
-
-void RoutedZone::get_graph(xbt_graph_t graph, std::map<std::string, xbt_node_t>* nodes,
- std::map<std::string, xbt_edge_t>* edges)
-{
- std::vector<kernel::routing::NetPoint*> vertices = get_vertices();
-
- for (auto const& my_src : vertices) {
- for (auto const& my_dst : vertices) {
- if (my_src == my_dst)
- continue;
-
- RouteCreationArgs* route = new RouteCreationArgs();
-
- get_local_route(my_src, my_dst, route, nullptr);
-
- XBT_DEBUG("get_route_and_latency %s -> %s", my_src->get_cname(), my_dst->get_cname());
-
- xbt_node_t current;
- xbt_node_t previous;
- const char *previous_name;
- const char *current_name;
-
- if (route->gw_src) {
- previous = new_xbt_graph_node(graph, route->gw_src->get_cname(), nodes);
- previous_name = route->gw_src->get_cname();
- } else {
- previous = new_xbt_graph_node(graph, my_src->get_cname(), nodes);
- previous_name = my_src->get_cname();
- }
-
- for (auto const& link : route->link_list) {
- const char* link_name = link->get_cname();
- current = new_xbt_graph_node(graph, link_name, nodes);
- current_name = link_name;
- new_xbt_graph_edge(graph, previous, current, edges);
- XBT_DEBUG(" %s -> %s", previous_name, current_name);
- previous = current;
- previous_name = current_name;
- }
-
- if (route->gw_dst) {
- current = new_xbt_graph_node(graph, route->gw_dst->get_cname(), nodes);
- current_name = route->gw_dst->get_cname();
- } else {
- current = new_xbt_graph_node(graph, my_dst->get_cname(), nodes);
- current_name = my_dst->get_cname();
- }
- new_xbt_graph_edge(graph, previous, current, edges);
- XBT_DEBUG(" %s -> %s", previous_name, current_name);
-
- delete route;
- }
- }
-}