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

Private GIT Repository
Cosmetics: move around a line in initial summary.
[loba.git] / hostdata.cpp
index b75633a4fecd4497e3ab404352dc6bd6785d9fa4..ee8fadce107447fa32c0a3e7da307130ac89758f 100644 (file)
@@ -1,42 +1,56 @@
-#include "hostdata.h"
-
-#include <xbt/log.h>
+#include <algorithm>
+#include <cstring>
+#include <functional>
 #include <stdexcept>
+#include <xbt/log.h>
+#include <xbt/sysdep.h>
 
 XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(main);
 
-hostdata* hostdata::instances = NULL;
+#include "misc.h"
+#include "options.h"
+
+#include "hostdata.h"
+
+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();
-    VERB1("Got %d hosts.", nhosts);
+    // 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));
+    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;
+    XBT_LOG(logp, "Got %zu hosts.", hosts.size());
     for (int i = 0; i < nhosts; i++) {
-        hostdata* h = new hostdata(host_list[i]);
-        MSG_host_set_data(host_list[i], h);
-        VERB2("Host #%d named \"%s\".", i, h->get_name());
-        h->next = instances;
-        instances = h;
+        XBT_LOG(logp, "Host #%d named \"%s\".", i, hosts[i].get_name());
     }
-    xbt_free(host_list);
 }
 
 void hostdata::destroy()
 {
-    while (instances) {
-        hostdata* h = instances;
-        instances = h->next;
-        delete h;
-    }
+    // hosts are automatically destroyed...
 }
 
 hostdata::hostdata(m_host_t host)
-    : next(NULL)
-    , name(MSG_host_get_name(host))
+    : name(MSG_host_get_name(host))
     , ctrl_mbox(std::string(name) + "_ctrl")
     , data_mbox(std::string(name) + "_data")
 {
+    MSG_host_set_data(host, this);
 }
 
 hostdata::~hostdata()