X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b7bae6a27325376248620283dafc43915142b254..a079934fedd2dbda265e0511fd5ba6b344404875:/include/simgrid/s4u/Engine.hpp diff --git a/include/simgrid/s4u/Engine.hpp b/include/simgrid/s4u/Engine.hpp index e705bab613..8b2f0cdc93 100644 --- a/include/simgrid/s4u/Engine.hpp +++ b/include/simgrid/s4u/Engine.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2006-2017. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2006-2018. 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. */ @@ -13,14 +13,12 @@ #include #include +#include #include -#include +#include namespace simgrid { -namespace kernel { -class EngineImpl; -} namespace s4u { /** @brief Simulation engine * @@ -56,8 +54,22 @@ public: /** @brief Load a deployment file and launch the actors that it contains */ void loadDeployment(const char* deploy); +protected: + friend s4u::Host; + void addHost(std::string name, simgrid::s4u::Host * host); + void delHost(std::string name); + +public: + simgrid::s4u::Host* hostByName(std::string name); + simgrid::s4u::Host* hostByNameOrNull(std::string name); + size_t getHostCount(); void getHostList(std::vector * whereTo); + std::vector getHostList(); + + size_t getLinkCount(); + void getLinkList(std::vector * list); + std::vector getLinkList(); /** @brief Run the simulation */ void run(); @@ -74,6 +86,8 @@ public: /** @brief Retrieve the netzone of the given name (or nullptr if not found) */ simgrid::s4u::NetZone* getNetzoneByNameOrNull(const char* name); + /** @brief Retrieves all netzones of the same type than the subtype of the whereto vector */ + template void getNetzoneByType(std::vector * whereto) { netzoneByTypeRecursive(getNetRoot(), whereto); } /** @brief Retrieve the netcard of the given name (or nullptr if not found) */ simgrid::kernel::routing::NetPoint* getNetpointByNameOrNull(std::string name); void getNetpointList(std::vector * list); @@ -117,13 +131,25 @@ private: /** Callback fired when the platform is created (ie, the xml file parsed), * right before the actual simulation starts. */ -extern XBT_PRIVATE xbt::signal onPlatformCreated; +extern XBT_PUBLIC(xbt::signal) onPlatformCreated; /** Callback fired when the main simulation loop ends, just before MSG_run (or similar) ends */ -extern XBT_PRIVATE xbt::signal onSimulationEnd; +extern XBT_PUBLIC(xbt::signal) onSimulationEnd; /** Callback fired when the time jumps into the future */ -extern XBT_PRIVATE xbt::signal onTimeAdvance; +extern XBT_PUBLIC(xbt::signal) onTimeAdvance; + +/** Callback fired when the time cannot jump because of inter-actors deadlock */ +extern XBT_PUBLIC(xbt::signal) onDeadlock; + +template XBT_PRIVATE void netzoneByTypeRecursive(s4u::NetZone* current, std::vector* whereto) +{ + for (auto const& elem : *(current->getChildren())) { + netzoneByTypeRecursive(elem, whereto); + if (elem == dynamic_cast(elem)) + whereto->push_back(dynamic_cast(elem)); + } +} } } // namespace simgrid::s4u