X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/88fad0aaff9eb463f048bfdfe4ad6218aba44ddb..68a9fafbcfc63baa653304e2e2129a00a0a445a6:/examples/s4u/actor-kill/s4u-actor-kill.cpp diff --git a/examples/s4u/actor-kill/s4u-actor-kill.cpp b/examples/s4u/actor-kill/s4u-actor-kill.cpp index 366364088e..902d2cf7b0 100644 --- a/examples/s4u/actor-kill/s4u-actor-kill.cpp +++ b/examples/s4u/actor-kill/s4u-actor-kill.cpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2017 The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2017-2018. 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. */ @@ -7,15 +7,9 @@ XBT_LOG_NEW_DEFAULT_CATEGORY(s4u_actor_kill, "Messages specific for this s4u example"); -static int on_exit(void*, void*) -{ - XBT_INFO("I have been killed!"); - return 0; -} - static void victimA_fun() { - simgrid::s4u::this_actor::onExit(on_exit, nullptr); + simgrid::s4u::this_actor::on_exit([](int, void*) { XBT_INFO("I have been killed!"); }, nullptr); XBT_INFO("Hello!"); XBT_INFO("Suspending myself"); simgrid::s4u::this_actor::suspend(); /* - Start by suspending itself */ @@ -33,9 +27,9 @@ static void killer() { XBT_INFO("Hello!"); /* - First start a victim process */ simgrid::s4u::ActorPtr victimA = - simgrid::s4u::Actor::createActor("victim A", simgrid::s4u::Host::by_name("Fafard"), victimA_fun); + simgrid::s4u::Actor::create("victim A", simgrid::s4u::Host::by_name("Fafard"), victimA_fun); simgrid::s4u::ActorPtr victimB = - simgrid::s4u::Actor::createActor("victim B", simgrid::s4u::Host::by_name("Jupiter"), victimB_fun); + simgrid::s4u::Actor::create("victim B", simgrid::s4u::Host::by_name("Jupiter"), victimB_fun); simgrid::s4u::this_actor::sleep_for(10); /* - Wait for 10 seconds */ XBT_INFO("Resume the victim A"); /* - Resume it from its suspended state */ @@ -43,7 +37,7 @@ static void killer() simgrid::s4u::this_actor::sleep_for(2); XBT_INFO("Kill the victim A"); /* - and then kill it */ - simgrid::s4u::Actor::kill(victimA->getPid()); // Kill by PID is legit + simgrid::s4u::Actor::kill(victimA->get_pid()); // Kill by PID is legit simgrid::s4u::this_actor::sleep_for(1); @@ -52,13 +46,20 @@ static void killer() simgrid::s4u::this_actor::sleep_for(1); + XBT_INFO("Start a new actor, and kill it right away"); + simgrid::s4u::ActorPtr victimC = + simgrid::s4u::Actor::create("victim C", simgrid::s4u::Host::by_name("Jupiter"), victimA_fun); + victimC->kill(); + + simgrid::s4u::this_actor::sleep_for(1); + XBT_INFO("Killing everybody but myself"); - simgrid::s4u::Actor::killAll(); + simgrid::s4u::Actor::kill_all(); XBT_INFO("OK, goodbye now. I commit a suicide."); - simgrid::s4u::this_actor::kill(); + simgrid::s4u::this_actor::exit(); - XBT_INFO("This line will never get displayed: I'm already dead since the previous line."); + XBT_INFO("This line never gets displayed: I'm already dead since the previous line."); } int main(int argc, char* argv[]) @@ -66,13 +67,11 @@ int main(int argc, char* argv[]) simgrid::s4u::Engine e(&argc, argv); xbt_assert(argc == 2, "Usage: %s platform_file\n\tExample: %s msg_platform.xml\n", argv[0], argv[0]); - e.loadPlatform(argv[1]); /* - Load the platform description */ + e.load_platform(argv[1]); /* - Load the platform description */ /* - Create and deploy killer process, that will create the victim actors */ - simgrid::s4u::Actor::createActor("killer", simgrid::s4u::Host::by_name("Tremblay"), killer); + simgrid::s4u::Actor::create("killer", simgrid::s4u::Host::by_name("Tremblay"), killer); e.run(); /* - Run the simulation */ - XBT_INFO("Simulation time %g", e.getClock()); - return 0; }