1 #include "Master.hpp"
\r
2 #include "BasicTask.hpp"
\r
3 #include "FinalizeTask.hpp"
\r
6 #include <HostNotFoundException.hpp>
\r
10 MSG_IMPLEMENT_DYNAMIC(Master, Process);
\r
12 int Master::main(int argc, char** argv)
\r
15 double taskComputeSize;
\r
16 double taskCommunicateSize;
\r
21 info(TEXT_("argc=") + TEXT_(argc));
\r
23 for (int i = 0; i< argc; i++)
\r
24 info(TEXT_("argv:") + TEXT_(argv[i]));
\r
26 sscanf(argv[0],"%d", &taskCount);
\r
28 sscanf(argv[1],"%lg", &taskComputeSize);
\r
30 sscanf(argv[2],"%lg", &taskCommunicateSize);
\r
32 BasicTaskPtr* basicTasks = new BasicTaskPtr[taskCount];
\r
34 for (int i = 0; i < taskCount; i++)
\r
35 basicTasks[i] = new BasicTask(TEXT_("Task_") + TEXT_(i), taskComputeSize, taskCommunicateSize);
\r
37 int aliasCount = argc - 3;
\r
39 char** aliases = (char**) calloc(aliasCount, sizeof(char*));
\r
41 for(int i = 3; i < argc ; i++)
\r
42 aliases[i - 3] = _strdup(argv[i]);
\r
44 info(TEXT_("Got ") + TEXT_(aliasCount) + TEXT_(" alias(es) :"));
\r
46 for (int i = 0; i < aliasCount; i++)
\r
47 info(TEXT_("\t") + TEXT_(aliases[i]));
\r
49 info(TEXT_("Got ") + TEXT_(taskCount) + TEXT_(" task to process."));
\r
51 for (int i = 0; i < taskCount; i++)
\r
53 info(TEXT_("Sending \"") + TEXT_(basicTasks[i]->getName()) + TEXT_("\" to \"") + TEXT_(aliases[i % aliasCount]) + TEXT_("\""));
\r
56 /*if((Host::currentHost().getName()).equals((aliases[i % aliasCount].split(":"))[0]))
\r
57 info("Hey ! It's me ! ");
\r
60 basicTasks[i]->send(aliases[i % aliasCount]);
\r
63 info("Send completed");
\r
65 info("All tasks have been dispatched. Let's tell everybody the computation is over.");
\r
67 FinalizeTask* finalizeTask;
\r
69 for (int i = 0; i < aliasCount; i++)
\r
71 finalizeTask = new FinalizeTask();
\r
72 finalizeTask->send(aliases[i]);
\r
76 info("Goodbye now!");
\r
78 delete[] basicTasks;
\r