Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
please sonar and do the same in teshsuite
[simgrid.git] / teshsuite / s4u / pid / pid.cpp
index 4b45749..552f17c 100644 (file)
@@ -1,5 +1,4 @@
-/* Copyright (c) 2009-2010, 2013-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. */
@@ -8,11 +7,7 @@
 
 XBT_LOG_NEW_DEFAULT_CATEGORY(s4u_test, "Messages specific for this msg example");
 
-simgrid::s4u::MailboxPtr mailbox = simgrid::s4u::Mailbox::byName("mailbox");
-double comp_size                 = 1000;
-double comm_size                 = 100000;
-
-static int my_onexit(smx_process_exit_status_t status, int* pid)
+static int my_onexit(smx_process_exit_status_t /*status*/, int* pid)
 {
   XBT_INFO("Process \"%d\" killed.", *pid);
   return 0;
@@ -20,11 +15,13 @@ static int my_onexit(smx_process_exit_status_t status, int* pid)
 
 static void sendpid()
 {
-  int pid = simgrid::s4u::this_actor::pid();
+  simgrid::s4u::MailboxPtr mailbox = simgrid::s4u::Mailbox::byName("mailbox");
+  int pid                          = simgrid::s4u::this_actor::getPid();
+  double comm_size                 = 100000;
   simgrid::s4u::this_actor::onExit((int_f_pvoid_pvoid_t)my_onexit, &pid);
 
   XBT_INFO("Sending pid of \"%d\".", pid);
-  simgrid::s4u::this_actor::send(mailbox, &pid, comm_size);
+  mailbox->put(&pid, comm_size);
   XBT_INFO("Send of pid \"%d\" done.", pid);
 
   simgrid::s4u::this_actor::suspend();
@@ -32,8 +29,9 @@ static void sendpid()
 
 static void killall()
 {
+  simgrid::s4u::MailboxPtr mailbox = simgrid::s4u::Mailbox::byName("mailbox");
   for (int i = 0; i < 3; i++) {
-    int* pid = static_cast<int*>(simgrid::s4u::this_actor::recv(mailbox));
+    int* pid = static_cast<int*>(mailbox->get());
     XBT_INFO("Killing process \"%d\".", *pid);
     simgrid::s4u::Actor::byPid(*pid)->kill();
   }
@@ -41,8 +39,8 @@ static void killall()
 
 int main(int argc, char* argv[])
 {
-  simgrid::s4u::Engine* e = new simgrid::s4u::Engine(&argc, argv);
-  e->loadPlatform(argv[1]);
+  simgrid::s4u::Engine e(&argc, argv);
+  e.loadPlatform(argv[1]);
 
   if (argc > 2)
     simgrid::s4u::Actor::killAll(atoi(argv[2]));
@@ -54,7 +52,7 @@ int main(int argc, char* argv[])
   simgrid::s4u::Actor::createActor("sendpid", simgrid::s4u::Host::by_name("Tremblay"), sendpid);
   simgrid::s4u::Actor::createActor("killall", simgrid::s4u::Host::by_name("Tremblay"), killall);
 
-  e->run();
+  e.run();
 
   return 0;
 }