X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/loba.git/blobdiff_plain/10e5dbdfc7cf72a000a90a2f1a27c7dc30364761..ed1b60f32b208ae07cc1f9d4d1aaa38f78359f53:/hostdata.cpp?ds=sidebyside

diff --git a/hostdata.cpp b/hostdata.cpp
index ee8fadc..be62d4d 100644
--- a/hostdata.cpp
+++ b/hostdata.cpp
@@ -1,6 +1,5 @@
 #include <algorithm>
 #include <cstring>
-#include <functional>
 #include <stdexcept>
 #include <xbt/log.h>
 #include <xbt/sysdep.h>
@@ -16,18 +15,15 @@ std::vector<hostdata> hostdata::hosts;
 
 void hostdata::create()
 {
-    using std::placeholders::_1;
-    using std::placeholders::_2;
-
-    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,
-                  std::bind(std::less<int>(),
-                            std::bind(strcmp,
-                                      std::bind(MSG_host_get_name, _1),
-                                      std::bind(MSG_host_get_name, _2)), 0));
+                  [](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);
 
@@ -45,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")