X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/ab0bf820128e74dc5e7d9e6413b88bca2621a34e..4bd1f48f0bf1ad1703be680ec2a38d626c6a2668:/src/msg/msg_actions.cpp diff --git a/src/msg/msg_actions.cpp b/src/msg/msg_actions.cpp index 1fd0b4133a..917c86883e 100644 --- a/src/msg/msg_actions.cpp +++ b/src/msg/msg_actions.cpp @@ -1,61 +1,56 @@ -/* Copyright (c) 2009-2015. The SimGrid Team. - * All rights reserved. */ +/* Copyright (c) 2009-2017. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ -#include "msg_private.h" -#include "xbt/dynar.h" -#include "xbt/replay.h" +#include "src/msg/msg_private.h" +#include "xbt/replay.hpp" -#include +#include 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); + MSG_function_register_default(simgrid::xbt::replay_runner); } void MSG_action_exit() { - _xbt_replay_action_exit(); + // Nothing to do anymore here } /** \ingroup msg_trace_driven * \brief A trace loader * - * If path!=NULL, load a trace file containing actions, and execute them. + * If path!=nullptr, load a trace file containing actions, and execute them. * Else, assume that each process gets the path in its deployment file */ msg_error_t MSG_action_trace_run(char *path) { - msg_error_t res; - char *name; - xbt_dynar_t todo; - xbt_dict_cursor_t cursor; - - xbt_action_fp=NULL; if (path) { - xbt_action_fp = fopen(path, "r"); - xbt_assert(xbt_action_fp != NULL, "Cannot open %s: %s", path, strerror(errno)); + simgrid::xbt::action_fs = new std::ifstream(path, std::ifstream::in); } - res = MSG_main(); - if (!xbt_dict_is_empty(xbt_action_queues)) { + msg_error_t res = MSG_main(); + + if (not simgrid::xbt::action_queues.empty()) { XBT_WARN("Not all actions got consumed. If the simulation ended successfully (without deadlock)," " you may want to add new processes to your deployment file."); - xbt_dict_foreach(xbt_action_queues, cursor, name, todo) { - XBT_WARN("Still %lu actions for %s", xbt_dynar_length(todo), name); + for (auto const& actions_of : simgrid::xbt::action_queues) { + XBT_WARN("Still %zu actions for %s", actions_of.second->size(), actions_of.first.c_str()); } } - if (path) - fclose(xbt_action_fp); - xbt_dict_free(&xbt_action_queues); - xbt_action_queues = xbt_dict_new_homogeneous(NULL); + if (path) { + delete simgrid::xbt::action_fs; + simgrid::xbt::action_fs = nullptr; + } return res; } + +SG_END_DECL()