X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/47ba551ee792c3cc4a5960dfb0dc9c42d08509d3..de00769095da24e77ceab237b324c2c3a4f94a9d:/include/simgrid/kernel/routing/NetZoneImpl.hpp diff --git a/include/simgrid/kernel/routing/NetZoneImpl.hpp b/include/simgrid/kernel/routing/NetZoneImpl.hpp index 55a1748a6f..ed13e52c52 100644 --- a/include/simgrid/kernel/routing/NetZoneImpl.hpp +++ b/include/simgrid/kernel/routing/NetZoneImpl.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2016-2022. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2016-2023. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -16,9 +16,7 @@ #include #include -namespace simgrid { -namespace kernel { -namespace routing { +namespace simgrid::kernel::routing { class Route { public: @@ -76,12 +74,13 @@ class XBT_PUBLIC NetZoneImpl : public xbt::PropertyHolder { s4u::NetZone piface_; // our content, as known to our graph routing algorithm (maps vertex_id -> vertex) - std::vector vertices_; + std::vector vertices_; std::map> links_; /* save split-duplex links separately, keep links_ with only LinkImpl* seen by the user * members of a split-duplex are saved in the links_ */ std::map, std::less<>> split_duplex_links_; std::map> hosts_; + std::map> gateways_; NetZoneImpl* parent_ = nullptr; std::vector children_; // sub-netzones @@ -89,7 +88,7 @@ class XBT_PUBLIC NetZoneImpl : public xbt::PropertyHolder { bool sealed_ = false; // We cannot add more content when sealed std::map, BypassRoute*> bypass_routes_; // src x dst -> route - routing::NetPoint* netpoint_ = nullptr; // Our representative in the parent NetZone + NetPoint* netpoint_ = nullptr; // Our representative in the parent NetZone protected: explicit NetZoneImpl(const std::string& name); @@ -144,7 +143,7 @@ public: const s4u::NetZone* get_iface() const { return &piface_; } s4u::NetZone* get_iface() { return &piface_; } unsigned int get_table_size() const { return vertices_.size(); } - std::vector get_vertices() const { return vertices_; } + std::vector get_vertices() const { return vertices_; } NetZoneImpl* get_parent() const { return parent_; } /** @brief Returns the list of direct children (no grand-children). This returns the internal data, no copy. * Don't mess with it.*/ @@ -158,7 +157,12 @@ public: const char* get_cname() const { return name_.c_str(); }; /** @brief Gets the netpoint associated to this netzone */ - kernel::routing::NetPoint* get_netpoint() const { return netpoint_; } + NetPoint* get_netpoint() const { return netpoint_; } + + void set_gateway(const std::string& name, NetPoint* router); + /** @brief Gets the gateway associated to this netzone */ + NetPoint* get_gateway() const; + NetPoint* get_gateway(const std::string& name) const { return gateways_.at(name); } std::vector get_all_hosts() const; size_t get_host_count() const; @@ -269,7 +273,7 @@ public: /*** Called on each newly created regular route (not on bypass routes) */ static xbt::signal const& link_list)> - on_route_creation; // XBT_ATTRIB_DEPRECATED_v332 : should be an internal signal used by NS3.. if necessary, + on_route_creation; // FIXME: XBT_ATTRIB_DEPRECATED_v332: should be an internal signal used by NS3.. if necessary, // callback shouldn't use LinkImpl* private: @@ -287,8 +291,6 @@ private: virtual resource::StandardLinkImpl* do_create_link(const std::string& name, const std::vector& bandwidths); void add_child(NetZoneImpl* new_zone); }; -} // namespace routing -} // namespace kernel -} // namespace simgrid +} // namespace simgrid::kernel::routing #endif /* SIMGRID_ROUTING_NETZONEIMPL_HPP */