X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/eb650ffefc6fb7d05ad74b4d5f79f402f4b7f878..117bc6048d5a60b7516f35eccfa101707d54c47f:/src/s4u/s4u_engine.cpp diff --git a/src/s4u/s4u_engine.cpp b/src/s4u/s4u_engine.cpp index 0e983e8ffe..783ed43c4a 100644 --- a/src/s4u/s4u_engine.cpp +++ b/src/s4u/s4u_engine.cpp @@ -32,11 +32,11 @@ Engine *Engine::instance_ = nullptr; /* That singleton is awful, but I don't see Engine::Engine(int *argc, char **argv) { xbt_assert(s4u::Engine::instance_ == nullptr, "It is currently forbidden to create more than one instance of s4u::Engine"); - s4u::Engine::instance_ = this; - pimpl = new kernel::EngineImpl(); - - TRACE_global_init(argc, argv); + TRACE_global_init(); SIMIX_global_init(argc, argv); + + pimpl = new kernel::EngineImpl(); + s4u::Engine::instance_ = this; } Engine::~Engine() @@ -54,6 +54,7 @@ Engine* Engine::getInstance() void Engine::shutdown() { delete s4u::Engine::instance_; + s4u::Engine::instance_ = nullptr; } double Engine::getClock() @@ -88,7 +89,7 @@ size_t Engine::getHostCount() /** @brief Fills the passed list with all hosts found in the platform */ void Engine::getHostList(std::vector* list) { - for (auto kv : host_list) + for (auto const& kv : host_list) list->push_back(kv.second); } @@ -110,7 +111,7 @@ static s4u::NetZone* netzoneByNameRecursive(s4u::NetZone* current, const char* n if (not strcmp(current->getCname(), name)) return current; - for (auto elem : *(current->getChildren())) { + for (auto const& elem : *(current->getChildren())) { simgrid::s4u::NetZone* tmp = netzoneByNameRecursive(elem, name); if (tmp != nullptr) { return tmp; @@ -126,16 +127,16 @@ NetZone* Engine::getNetzoneByNameOrNull(const char* name) } /** @brief Retrieve the netpoint of the given name (or nullptr if not found) */ -simgrid::kernel::routing::NetPoint* Engine::getNetpointByNameOrNull(const char* name) +simgrid::kernel::routing::NetPoint* Engine::getNetpointByNameOrNull(std::string name) { - if (pimpl->netpoints_.find(name) == pimpl->netpoints_.end()) - return nullptr; - return pimpl->netpoints_.at(name); + auto netp = pimpl->netpoints_.find(name); + return netp == pimpl->netpoints_.end() ? nullptr : netp->second; } + /** @brief Fill the provided vector with all existing netpoints */ void Engine::getNetpointList(std::vector* list) { - for (auto kv : pimpl->netpoints_) + for (auto const& kv : pimpl->netpoints_) list->push_back(kv.second); } /** @brief Register a new netpoint to the system */