]> AND Private Git Repository - loba.git/blobdiff - hostdata.cpp
Logo AND Algorithmique Numérique Distribuée

Private GIT Repository
Use git diff instead of diff-index for setlocalversion.
[loba.git] / hostdata.cpp
index 787b7ab926a3804c961c7ba3dd7c1a53e4b84671..be62d4d83129d252bb3edb35ac4e951bf53c8190 100644 (file)
@@ -1,5 +1,5 @@
-#include <cstring>
 #include <algorithm>
+#include <cstring>
 #include <stdexcept>
 #include <xbt/log.h>
 #include <xbt/sysdep.h>
@@ -13,23 +13,17 @@ XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(main);
 
 std::vector<hostdata> 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<msg_host_t*>(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")