Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
reorg and more functions in namespace
[simgrid.git] / src / msg / msg_actions.cpp
index 2ad8a58..567209f 100644 (file)
@@ -4,21 +4,23 @@
  * under the terms of the license (GNU LGPL) which comes with this package. */
 
 #include "src/msg/msg_private.h"
-#include "xbt/replay.h"
+#include "xbt/replay.hpp"
 
 #include <errno.h>
 
 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(msg_action, msg, "MSG actions for trace driven simulation");
 
+SG_BEGIN_DECL()
+
 void MSG_action_init()
 {
-  _xbt_replay_action_init();
-  MSG_function_register_default(xbt_replay_action_runner);
+  simgrid::xbt::replay_init();
+  MSG_function_register_default(simgrid::xbt::replay_runner);
 }
 
 void MSG_action_exit()
 {
-  _xbt_replay_action_exit();
+  simgrid::xbt::replay_exit();
 }
 
 /** \ingroup msg_trace_driven
@@ -34,10 +36,8 @@ msg_error_t MSG_action_trace_run(char *path)
   xbt_dynar_t todo;
   xbt_dict_cursor_t cursor;
 
-  xbt_action_fp=nullptr;
   if (path) {
-    xbt_action_fp = fopen(path, "r");
-    xbt_assert(xbt_action_fp != nullptr, "Cannot open %s: %s", path, strerror(errno));
+    simgrid::xbt::action_fs = new std::ifstream(path, std::ifstream::in);
   }
   res = MSG_main();
 
@@ -50,10 +50,15 @@ msg_error_t MSG_action_trace_run(char *path)
     }
   }
 
-  if (path)
-    fclose(xbt_action_fp);
+  if (path) {
+    delete simgrid::xbt::action_fs;
+    simgrid::xbt::action_fs = nullptr;
+  }
+
   xbt_dict_free(&xbt_action_queues);
   xbt_action_queues = xbt_dict_new_homogeneous(nullptr);
 
   return res;
 }
+
+SG_END_DECL()