X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/08a84c431a7353119e36570ce5bfaeedc6bdf235..2f37dba04ea44bc979a25129f10b18797b6fec1e:/src/s4u/s4u_Engine.cpp diff --git a/src/s4u/s4u_Engine.cpp b/src/s4u/s4u_Engine.cpp index 0a0a3b38bb..eb3ff86f30 100644 --- a/src/s4u/s4u_Engine.cpp +++ b/src/s4u/s4u_Engine.cpp @@ -80,6 +80,10 @@ void Engine::register_function(std::string name, int (*code)(int, char**)) { SIMIX_function_register(name, code); } +void Engine::register_function(std::string name, void (*code)(std::vector)) +{ + SIMIX_function_register(name, code); +} void Engine::register_default(int (*code)(int, char**)) { SIMIX_function_register_default(code); @@ -93,16 +97,7 @@ size_t Engine::get_host_count() { return pimpl->hosts_.size(); } -/** @brief Fills the passed list with all hosts found in the platform - * @deprecated Please prefer Engine::getAllHosts() - */ -void Engine::getHostList(std::vector* list) -{ - for (auto const& kv : pimpl->hosts_) - list->push_back(kv.second); -} -/** @brief Returns the list of all hosts found in the platform */ std::vector Engine::get_all_hosts() { std::vector res; @@ -132,18 +127,18 @@ void Engine::host_unregister(std::string name) pimpl->hosts_.erase(name); } -/** @brief Find an host from its name. +/** @brief Find a host from its name. * * @throw std::invalid_argument if the searched host does not exist. */ simgrid::s4u::Host* Engine::host_by_name(std::string name) { if (pimpl->hosts_.find(name) == pimpl->hosts_.end()) - throw std::invalid_argument(std::string("Host not found: ") + name); + throw std::invalid_argument(std::string("Host not found: '") + name + std::string("'")); return pimpl->hosts_.at(name); } -/** @brief Find an host from its name (or nullptr if that host does not exist) */ +/** @brief Find a host from its name (or nullptr if that host does not exist) */ simgrid::s4u::Host* Engine::host_by_name_or_null(std::string name) { auto host = pimpl->hosts_.find(name); @@ -200,7 +195,7 @@ std::vector Engine::get_all_storages() */ simgrid::s4u::Storage* Engine::storage_by_name(std::string name) { - if (pimpl->links_.find(name) == pimpl->links_.end()) + if (pimpl->storages_.find(name) == pimpl->storages_.end()) throw std::invalid_argument(std::string("Storage not found: ") + name); return pimpl->storages_.at(name); @@ -366,28 +361,32 @@ void Engine::set_config(std::string str) } // namespace simgrid /* **************************** Public C interface *************************** */ -void sg_engine_load_platform(const char* file) +void simgrid_init(int* argc, char** argv) +{ + simgrid::s4u::Engine e(argc, argv); +} +void simgrid_load_platform(const char* file) { simgrid::s4u::Engine::get_instance()->load_platform(file); } -void sg_engine_load_deployment(const char* file) +void simgrid_load_deployment(const char* file) { simgrid::s4u::Engine::get_instance()->load_deployment(file); } -void sg_engine_run() +void simgrid_run() { simgrid::s4u::Engine::get_instance()->run(); } -void sg_engine_register_function(const char* name, int (*code)(int, char**)) +void simgrid_register_function(const char* name, int (*code)(int, char**)) { simgrid::s4u::Engine::get_instance()->register_function(name, code); } -void sg_engine_register_default(int (*code)(int, char**)) +void simgrid_register_default(int (*code)(int, char**)) { simgrid::s4u::Engine::get_instance()->register_default(code); } -double sg_engine_get_clock() +double simgrid_get_clock() { return simgrid::s4u::Engine::get_clock(); }