X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b8dae0fb0df3dd5c66241e88f1f574c687c504f9..9da45f53bdedff9ac9320a7a3c2ac1d5b9184ce2:/src/s4u/s4u_Engine.cpp?ds=sidebyside diff --git a/src/s4u/s4u_Engine.cpp b/src/s4u/s4u_Engine.cpp index d522abf243..ac01c07206 100644 --- a/src/s4u/s4u_Engine.cpp +++ b/src/s4u/s4u_Engine.cpp @@ -14,6 +14,7 @@ #include "simgrid/s4u/NetZone.hpp" #include "simgrid/s4u/Storage.hpp" #include "simgrid/simix.h" +#include "src/simix/smx_private.hpp" // For access to simix_global->process_list #include "src/instr/instr_private.hpp" #include "src/kernel/EngineImpl.hpp" #include "src/surf/network_interface.hpp" @@ -140,6 +141,27 @@ simgrid::s4u::Host* Engine::host_by_name_or_null(std::string name) return host == pimpl->hosts_.end() ? nullptr : host->second; } +simgrid::s4u::Link* Engine::link_by_name(std::string name) +{ + return pimpl->links_.at(name); // Will raise a std::out_of_range if the host does not exist +} + +simgrid::s4u::Link* Engine::link_by_name_or_null(std::string name) +{ + auto link = pimpl->links_.find(name); + return link == pimpl->links_.end() ? nullptr : link->second; +} + +void Engine::link_register(std::string name, simgrid::s4u::Link* link) +{ + pimpl->links_[name] = link; +} + +void Engine::link_unregister(std::string name) +{ + pimpl->links_.erase(name); +} + /** @brief Returns the amount of storages in the platform */ size_t Engine::get_storage_count() { @@ -179,17 +201,52 @@ void Engine::storage_unregister(std::string name) /** @brief Returns the amount of links in the platform */ size_t Engine::get_link_count() { - return kernel::resource::LinkImpl::linksCount(); + return pimpl->links_.size(); } /** @brief Returns the list of all links found in the platform */ std::vector Engine::get_all_links() { std::vector res; - kernel::resource::LinkImpl::linksList(&res); + for (auto const& kv : pimpl->links_) + res.push_back(kv.second); return res; } +std::vector Engine::get_filtered_links(std::function filter) +{ + std::vector filtered_list; + for (auto const& kv : pimpl->links_) + if (filter(kv.second)) + filtered_list.push_back(kv.second); + return filtered_list; +} + +size_t Engine::get_actor_count() +{ + return simix_global->process_list.size(); +} + +std::vector Engine::get_all_actors() +{ + std::vector actor_list; + actor_list.push_back(simgrid::s4u::Actor::self()); + for (auto& kv : simix_global->process_list) { + actor_list.push_back(kv.second->iface()); + } + return actor_list; +} + +std::vector Engine::get_filtered_actors(std::function filter) +{ + std::vector actor_list; + for (auto& kv : simix_global->process_list) { + if (filter(kv.second->iface())) + actor_list.push_back(kv.second->iface()); + } + return actor_list; +} + void Engine::run() { if (MC_is_active()) { @@ -216,7 +273,7 @@ static s4u::NetZone* netzone_by_name_recursive(s4u::NetZone* current, const char if (not strcmp(current->get_cname(), name)) return current; - for (auto const& elem : *(current->getChildren())) { + for (auto const& elem : *(current->get_children())) { simgrid::s4u::NetZone* tmp = netzone_by_name_recursive(elem, name); if (tmp != nullptr) { return tmp;