-/* Copyright (c) 2006-2019. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2006-2021. 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 "simgrid/s4u/Engine.hpp"
#include "simgrid/simdag.h"
#include "surf/surf.hpp"
#include <set>
namespace sd{
class Global {
public:
+ explicit Global(int* argc, char** argv) : engine_(new simgrid::s4u::Engine(argc, argv)) {}
bool watch_point_reached = false; /* has a task just reached a watch point? */
std::set<SD_task_t> initial_tasks;
std::set<SD_task_t> runnable_tasks;
std::set<SD_task_t> completed_tasks;
std::set<SD_task_t> return_set;
+ s4u::Engine* engine_;
};
std::set<SD_task_t>* simulate (double how_long);
/* SimDag private functions */
XBT_PRIVATE void SD_task_set_state(SD_task_t task, e_SD_task_state_t new_state);
XBT_PRIVATE void SD_task_run(SD_task_t task);
-XBT_PRIVATE bool acyclic_graph_detail(xbt_dynar_t dag);
+XBT_PRIVATE bool acyclic_graph_detail(const_xbt_dynar_t dag);
XBT_PRIVATE void uniq_transfer_task_name(SD_task_t task);
XBT_PRIVATE const char *__get_state_name(e_SD_task_state_t state);
#endif