Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
bug-- and a bit less brain overload
[simgrid.git] / teshsuite / msg / pid / pid.c
index 8542e30..ebe6b3a 100644 (file)
@@ -5,10 +5,9 @@
  * under the terms of the license (GNU LGPL) which comes with this package. */
 
 #include "simgrid/msg.h"
-#include "xbt/sysdep.h"
 
-XBT_LOG_NEW_DEFAULT_CATEGORY(msg_test,
-                             "Messages specific for this msg example");
+XBT_LOG_NEW_DEFAULT_CATEGORY(msg_test, "Messages specific for this msg example");
+
 const char* mailbox = "mailbox";
 #define task_comp_size 1000
 #define task_comm_size 100000
@@ -32,10 +31,9 @@ static int sendpid(int argc, char *argv[])
 
 static int killall(int argc, char *argv[]){
   msg_task_t task = NULL;
-  XBT_ATTRIB_UNUSED int res;
-  int i;
-  for (i=0; i<3;i++) {
-    res = MSG_task_receive(&(task), mailbox);
+
+  for (int i=0; i<3;i++) {
+    MSG_task_receive(&(task), mailbox);
     int pid = *(int*)MSG_task_get_data(task);
     MSG_task_destroy(task);
     XBT_INFO("Killing process \"%d\".", pid);
@@ -45,25 +43,19 @@ static int killall(int argc, char *argv[]){
   return 0;
 }
 
-/** Main function */
-int main(int argc, char *argv[])
+int main(int argc, char* argv[])
 {
-  msg_error_t res = MSG_OK;
-
   MSG_init(&argc, argv);
 
-  /*   Application deployment */
-  MSG_function_register("sendpid", &sendpid);
-  MSG_function_register("killall", &killall);
+  xbt_assert(argc >= 2, "Usage: pid platform pid_to_kill");
 
-  MSG_process_killall(atoi(argv[3]));
+  MSG_process_killall(atoi(argv[2]));
 
   MSG_create_environment(argv[1]);
-  MSG_launch_application(argv[2]);
-  res = MSG_main();
+  MSG_process_create("sendpid", sendpid, NULL, MSG_get_host_by_name("Tremblay"));
+  MSG_process_create("sendpid", sendpid, NULL, MSG_get_host_by_name("Tremblay"));
+  MSG_process_create("sendpid", sendpid, NULL, MSG_get_host_by_name("Tremblay"));
+  MSG_process_create("killall", killall, NULL, MSG_get_host_by_name("Tremblay"));
 
-  if (res == MSG_OK)
-    return 0;
-  else
-    return 1;
+  return MSG_main() != MSG_OK;
 }