A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Move collective algorithms to separate folders
[simgrid.git]
/
src
/
s4u
/
s4u_netzone.cpp
diff --git
a/src/s4u/s4u_netzone.cpp
b/src/s4u/s4u_netzone.cpp
index
1ab825e
..
6aa572d
100644
(file)
--- a/
src/s4u/s4u_netzone.cpp
+++ b/
src/s4u/s4u_netzone.cpp
@@
-18,31
+18,30
@@
namespace s4u {
simgrid::xbt::signal<void(bool symmetrical, kernel::routing::NetPoint* src, kernel::routing::NetPoint* dst,
kernel::routing::NetPoint* gw_src, kernel::routing::NetPoint* gw_dst,
simgrid::xbt::signal<void(bool symmetrical, kernel::routing::NetPoint* src, kernel::routing::NetPoint* dst,
kernel::routing::NetPoint* gw_src, kernel::routing::NetPoint* gw_dst,
- std::vector<
Link
*>* link_list)>
+ std::vector<
surf::LinkImpl
*>* link_list)>
NetZone::onRouteCreation;
NetZone::NetZone(NetZone* father, const char* name) : father_(father), name_(xbt_strdup(name))
{
NetZone::onRouteCreation;
NetZone::NetZone(NetZone* father, const char* name) : father_(father), name_(xbt_strdup(name))
{
+ children_ = new std::vector<NetZone*>();
}
}
+
void NetZone::seal()
{
sealed_ = true;
}
void NetZone::seal()
{
sealed_ = true;
}
+
NetZone::~NetZone()
{
NetZone::~NetZone()
{
- xbt_dict_cursor_t cursor = nullptr;
- char* key;
- NetZone_t elem;
- xbt_dict_foreach (children_, cursor, key, elem) {
- delete static_cast<NetZone*>(elem);
- }
-
- xbt_dict_free(&children_);
+ for (auto nz : *children_)
+ delete nz;
+ delete children_;
xbt_free(name_);
}
xbt_free(name_);
}
+
std::unordered_map<std::string, std::string>* NetZone::properties()
{
std::unordered_map<std::string, std::string>* NetZone::properties()
{
- return simgrid::simix::kernelImmediate([
=
] {
+ return simgrid::simix::kernelImmediate([
this
] {
return &properties_;
});
}
return &properties_;
});
}
@@
-54,12
+53,12
@@
const char* NetZone::property(const char* key)
}
void NetZone::setProperty(const char* key, const char* value)
{
}
void NetZone::setProperty(const char* key, const char* value)
{
- simgrid::simix::kernelImmediate([
=,&key,&
value] {
+ simgrid::simix::kernelImmediate([
this,key,
value] {
properties_[key] = value;
});
}
properties_[key] = value;
});
}
-
xbt_dict_t
NetZone::children()
+
std::vector<NetZone*>*
NetZone::children()
{
return children_;
}
{
return children_;
}
@@
-72,16
+71,15
@@
NetZone* NetZone::father()
return father_;
}
return father_;
}
-
xbt_dynar_t
NetZone::hosts()
+
std::vector<s4u::Host*>*
NetZone::hosts()
{
{
- xbt_dynar_t res = xbt_dynar_new(sizeof(sg_host_t), nullptr);
-
- for (auto card : vertices_) {
- s4u::Host* host = simgrid::s4u::Host::by_name_or_null(card->name());
- if (host != nullptr)
- xbt_dynar_push(res, &host);
- }
- return res;
+ if (hosts_.empty()) // Lazy initialization
+ for (auto card : vertices_) {
+ s4u::Host* host = simgrid::s4u::Host::by_name_or_null(card->name());
+ if (host != nullptr)
+ hosts_.push_back(host);
+ }
+ return &hosts_;
}
int NetZone::addComponent(kernel::routing::NetPoint* elm)
}
int NetZone::addComponent(kernel::routing::NetPoint* elm)