X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/loba.git/blobdiff_plain/751ae9fcfc70b0b48670338c2273e2eaebc388d2..4d5ec9803b74d0f3e9c002a92a748bd08b6640ac:/hostdata.cpp diff --git a/hostdata.cpp b/hostdata.cpp index 787b7ab..be62d4d 100644 --- a/hostdata.cpp +++ b/hostdata.cpp @@ -1,5 +1,5 @@ -#include #include +#include #include #include #include @@ -13,23 +13,17 @@ XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(main); std::vector hostdata::hosts; -// 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; - } -}; - void hostdata::create() { - int nhosts = MSG_get_host_number(); - m_host_t* host_list = MSG_get_host_table(); + 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, m_host_less()); + std::sort(host_list, host_list + nhosts, + [](msg_host_t a, msg_host_t b) { + return std::strcmp(MSG_host_get_name(a), MSG_host_get_name(b)) < 0; + }); hosts.assign(host_list, host_list + nhosts); xbt_free(host_list); @@ -47,7 +41,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")