Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Routing: kill some dupplicated code
[simgrid.git] / src / surf / surf_routing_cluster.hpp
index 4588624..74018c5 100644 (file)
@@ -26,29 +26,22 @@ class XBT_PRIVATE AsCluster;
 
 class AsCluster: public AsNone {
 public:
-  AsCluster();
-
-  virtual void getRouteAndLatency(RoutingEdge *src, RoutingEdge *dst, sg_platf_route_cbarg_t into, double *latency);
-  //xbt_dynar_t getOneLinkRoutes();
-  //void parseRoute(sg_platf_route_cbarg_t route);
-  //void parseASroute(sg_platf_route_cbarg_t route);
-
-  void getGraph(xbt_graph_t graph, xbt_dict_t nodes, xbt_dict_t edges);
-  //sg_platf_route_cbarg_t getBypassRoute(RoutingEdge *src, RoutingEdge *dst, double *lat);
-
-  /* The parser calls the following functions to inform the routing models
-   * that a new element is added to the AS currently built.
-   *
-   * Of course, only the routing model of this AS is informed, not every ones */
-  int parsePU(RoutingEdge *elm); /* A host or a router, whatever */
-  int parseAS(RoutingEdge *elm);
+  AsCluster(const char*name);
+  void Seal() override {}; // nothing to do
+
+  virtual void getRouteAndLatency(NetCard *src, NetCard *dst, sg_platf_route_cbarg_t into, double *latency) override;
+  void getGraph(xbt_graph_t graph, xbt_dict_t nodes, xbt_dict_t edges) override;
+
   virtual void create_links_for_node(sg_platf_cluster_cbarg_t cluster, int id, int rank, int position);
-  Link* p_backbone;
-  void *p_loopback;
-  RoutingEdge *p_router;
-  int p_has_limiter;
-  int p_has_loopback;
-  int p_nb_links_per_node;
+  virtual void parse_specific_arguments(sg_platf_cluster_cbarg_t cluster) {}
+
+
+  Link* p_backbone = nullptr;
+  void *p_loopback = nullptr;
+  NetCard *p_router = nullptr;
+  int p_has_limiter = 0;
+  int p_has_loopback = 0;
+  int p_nb_links_per_node = 1;
 
 };