Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
d3d72aa8e922747e0f0caad7f49baf1f4e67676c
[simgrid.git] / src / kernel / routing / NetPoint.cpp
1 /* Copyright (c) 2009-2023. The SimGrid Team. All rights reserved.          */
2
3 /* This program is free software; you can redistribute it and/or modify it
4  * under the terms of the license (GNU LGPL) which comes with this package. */
5
6 #include "simgrid/kernel/routing/NetPoint.hpp"
7 #include "simgrid/kernel/routing/VivaldiZone.hpp"
8 #include "simgrid/s4u/Engine.hpp"
9 #include "simgrid/s4u/Host.hpp"
10 #include "xbt/log.h"
11
12 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(ker_netpoint, ker_routing, "Kernel implementation of netpoints");
13
14 namespace simgrid {
15
16 template class xbt::Extendable<kernel::routing::NetPoint>;
17
18 namespace kernel::routing {
19
20 simgrid::xbt::signal<void(NetPoint&)> NetPoint::on_creation;
21
22 NetPoint::NetPoint(const std::string& name, NetPoint::Type componentType) : name_(name), component_type_(componentType)
23 {
24   simgrid::s4u::Engine::get_instance()->netpoint_register(this);
25   simgrid::kernel::routing::NetPoint::on_creation(*this);
26 }
27
28 NetPoint* NetPoint::set_englobing_zone(NetZoneImpl* netzone_p)
29 {
30   englobing_zone_ = netzone_p;
31   if (netzone_p != nullptr)
32     id_ = netzone_p->add_component(this);
33   return this;
34 }
35
36 NetPoint* NetPoint::set_coordinates(const std::string& coords)
37 {
38   if (not coords.empty())
39     new vivaldi::Coords(this, coords);
40   return this;
41 }
42 } // namespace kernel::routing
43 } // namespace simgrid
44
45 /** @brief Retrieve a netpoint from its name
46  *
47  * Netpoints denote the location of host or routers in the network, to compute routes
48  */
49 simgrid::kernel::routing::NetPoint* sg_netpoint_by_name_or_null(const char* name)
50 {
51   return simgrid::s4u::Engine::get_instance()->netpoint_by_name_or_null(name);
52 }