X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/loba.git/blobdiff_plain/ba8a9c5fbc92dc95fc99d8078b3474fd2fd5a043..324204969dba501413a9f62de983806a6fddd6a0:/hostdata.cpp?ds=sidebyside diff --git a/hostdata.cpp b/hostdata.cpp index c15c0ee..88ca6fd 100644 --- a/hostdata.cpp +++ b/hostdata.cpp @@ -1,42 +1,43 @@ -#include "hostdata.h" - -#include #include +#include +#include #include #include #include -#include "misc.h" XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(main); -std::vector hostdata::hosts; +#include "misc.h" +#include "options.h" -// used to compare m_host_t's by name -struct hostdata::m_host_less { - bool operator()(const m_host_t& a, const m_host_t& b) - { - const char* na = MSG_host_get_name(a); - const char* nb = MSG_host_get_name(b); - return strcmp(na, nb) < 0; - } -}; +#include "hostdata.h" + +std::vector hostdata::hosts; void hostdata::create() { - int nhosts = MSG_get_host_number(); - m_host_t* host_list = MSG_get_host_table(); - // fixme: only sort hosts for automatically created deployment - // fixme: add an option to disable sorting - std::sort(host_list, host_list + nhosts, m_host_less()); + using std::placeholders::_1; + using std::placeholders::_2; + + xbt_dynar_t host_dynar = MSG_hosts_as_dynar(); + int nhosts = xbt_dynar_length(host_dynar); + msg_host_t* host_list = static_cast(xbt_dynar_to_array(host_dynar)); + // only sort hosts for automatically created deployment + if (opt::auto_depl::enabled) + std::sort(host_list, host_list + nhosts, + std::bind(std::less(), + std::bind(strcmp, + std::bind(MSG_host_get_name, _1), + std::bind(MSG_host_get_name, _2)), 0)); hosts.assign(host_list, host_list + nhosts); xbt_free(host_list); e_xbt_log_priority_t logp = xbt_log_priority_verbose; if (!LOG_ISENABLED(logp)) return; - LOG1(logp, "Got %lu hosts.", (unsigned long)hosts.size()); + XBT_LOG(logp, "Got %zu hosts.", hosts.size()); for (int i = 0; i < nhosts; i++) { - LOG2(logp, "Host #%d named \"%s\".", i, hosts[i].get_name()); + XBT_LOG(logp, "Host #%d named \"%s\".", i, hosts[i].get_name()); } } @@ -45,7 +46,7 @@ void hostdata::destroy() // hosts are automatically destroyed... } -hostdata::hostdata(m_host_t host) +hostdata::hostdata(msg_host_t host) : name(MSG_host_get_name(host)) , ctrl_mbox(std::string(name) + "_ctrl") , data_mbox(std::string(name) + "_data")