Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
This is our first modern exception. How stirring!
[simgrid.git] / teshsuite / s4u / actor-autorestart / actor-autorestart.cpp
1 /* Copyright (c) 2017-2018. The SimGrid Team. All rights reserved.          */
2
3 /* This program is free software; you can redistribute it and/or modify it
4  * under the terms of the license (GNU LGPL) which comes with this package. */
5
6 #include "simgrid/s4u.hpp"
7
8 XBT_LOG_NEW_DEFAULT_CATEGORY(s4u_test, "Messages specific for this s4u example");
9
10 static void dummy()
11 {
12   XBT_INFO("I start");
13   try {
14     simgrid::s4u::this_actor::sleep_for(200);
15     XBT_INFO("I stop");
16   } catch (simgrid::HostFailureException& e) {
17     XBT_DEBUG("The host has died ... as expected. This actor silently stops");
18   }
19 }
20
21 static void autostart()
22 {
23   simgrid::s4u::Host* host = simgrid::s4u::Host::by_name("Fafard");
24   XBT_INFO("starting a dummy process on %s ", host->get_cname());
25
26   simgrid::s4u::ActorPtr dummy_actor = simgrid::s4u::Actor::create("Dummy", host, dummy);
27   dummy_actor->set_auto_restart(true);
28
29   simgrid::s4u::this_actor::sleep_for(50);
30
31   XBT_INFO("powering off %s", host->get_cname());
32   host->turn_off();
33
34   simgrid::s4u::this_actor::sleep_for(10);
35
36   XBT_INFO("powering on %s", host->get_cname());
37   host->turn_on();
38   simgrid::s4u::this_actor::sleep_for(200);
39 }
40
41 int main(int argc, char* argv[])
42 {
43   simgrid::s4u::Engine e(&argc, argv);
44   e.load_platform(argv[1]);
45
46   simgrid::s4u::Actor::create("Autostart", simgrid::s4u::Host::by_name("Tremblay"), autostart);
47
48   e.run();
49   XBT_INFO("Simulation time %g", e.get_clock());
50
51   return 0;
52 }