Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "tconvert.h"
Toshihiro Shimizu 890ddd
#include "tfarmcontroller.h"
Toshihiro Shimizu 890ddd
#include "ttcpip.h"
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "texception.h"
Toshihiro Shimizu 890ddd
#include "tfarmproxy.h"
Toshihiro Shimizu 890ddd
#include "tfilepath_io.h"
Toshihiro Shimizu 890ddd
2fc36c
#include <sstream></sstream>
Shinya Kitaoka 9eb50d
Shinya Kitaoka 120a6e
namespace {
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka d1f6c4
class Controller final : public TFarmController, public TFarmProxy {
Toshihiro Shimizu 890ddd
public:
Shinya Kitaoka 120a6e
  Controller(const QString &hostName, const QString &addr, int port)
Shinya Kitaoka 120a6e
      : TFarmProxy(hostName, addr, port) {}
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // TFarmController interface implementation
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  QString addTask(const TFarmTask &task, bool suspended) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  void removeTask(const QString &id) override;
Shinya Kitaoka 473e70
  void suspendTask(const QString &id) override;
Shinya Kitaoka 473e70
  void activateTask(const QString &id) override;
Shinya Kitaoka 473e70
  void restartTask(const QString &id) override;
Toshihiro Shimizu 890ddd
otakuto 158f9f
  void getTasks(std::vector<qstring> &tasks) override;</qstring>
otakuto 158f9f
  void getTasks(const QString &parentId, std::vector<qstring> &tasks) override;</qstring>
otakuto 158f9f
  void getTasks(const QString &parentId,
otakuto 158f9f
                std::vector<taskshortinfo> &tasks) override;</taskshortinfo>
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  void queryTaskInfo(const QString &id, TFarmTask &task) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  void queryTaskShortInfo(const QString &id, QString &parentId, QString &name,
Shinya Kitaoka 473e70
                          TaskState &status) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 38fd86
  void attachServer(const QString &name, const QString &addr,
Shinya Kitaoka 38fd86
                    int port) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 38fd86
  void detachServer(const QString &name, const QString &addr,
Shinya Kitaoka 38fd86
                    int port) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  void taskSubmissionError(const QString &taskId, int errCode) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  void taskProgress(const QString &taskId, int step, int stepCount,
Shinya Kitaoka 473e70
                    int frameNumber, FrameState state) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  void taskCompleted(const QString &taskId, int exitCode) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // fills the servers vector with the names of the servers
otakuto 158f9f
  void getServers(std::vector<serveridentity> &servers) override;</serveridentity>
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // returns the state of the server whose id has been specified
Shinya Kitaoka 473e70
  ServerState queryServerState2(const QString &id) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // fills info with the infoes about the server whose id has been specified
Shinya Kitaoka 473e70
  void queryServerInfo(const QString &id, ServerInfo &info) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // activates the server whose id has been specified
Shinya Kitaoka 473e70
  void activateServer(const QString &id) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // deactivates the server whose id has been specified
Shinya Kitaoka 120a6e
  // once deactivated, a server is not available for task rendering
Shinya Kitaoka 38fd86
  void deactivateServer(const QString &id,
Shinya Kitaoka 38fd86
                        bool completeRunningTasks = true) override;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
QString Controller::addTask(const TFarmTask &task, bool suspended) {
Shinya Kitaoka 120a6e
  int i, count = task.getTaskCount();
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString data("addTask@TFarmTask_2");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += task.m_name;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += task.getCommandLine(true);
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += task.m_user;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += task.m_hostName;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(suspended);
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(task.m_stepCount);
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(task.m_priority);
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(task.m_platform);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  int depCount = task.m_dependencies->getTaskCount();
Shinya Kitaoka 120a6e
  data += QString::number(depCount);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  i = 0;
Shinya Kitaoka 120a6e
  for (; i < depCount; ++i) {
Shinya Kitaoka 120a6e
    data += ",";
Shinya Kitaoka 120a6e
    data += task.m_dependencies->getTaskId(i);
Shinya Kitaoka 120a6e
  }
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  for (i = 0; i < count; ++i) {
Shinya Kitaoka 120a6e
    TFarmTask &tt      = const_cast<tfarmtask &="">(task);</tfarmtask>
Shinya Kitaoka 120a6e
    TFarmTask *subtask = tt.getTask(i);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
    data += ",";
Shinya Kitaoka 120a6e
    data += subtask->m_name;
Shinya Kitaoka 120a6e
    data += ",";
Shinya Kitaoka 120a6e
    data += subtask->getCommandLine(true);
Shinya Kitaoka 120a6e
    data += ",";
Shinya Kitaoka 120a6e
    data += subtask->m_user;
Shinya Kitaoka 120a6e
    data += ",";
Shinya Kitaoka 120a6e
    data += subtask->m_hostName;
Shinya Kitaoka 120a6e
    data += ",";
Shinya Kitaoka 120a6e
    data += QString::number(subtask->m_stepCount);
Shinya Kitaoka 120a6e
    data += ",";
Shinya Kitaoka 120a6e
    data += QString::number(subtask->m_priority);
Shinya Kitaoka 120a6e
  }
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Shinya Kitaoka 120a6e
  // MessageBox(NULL, data.c_str(), "ciao", 0);
Shinya Kitaoka 120a6e
  return reply;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::removeTask(const QString &id) {
Shinya Kitaoka 120a6e
  QString data("removeTask");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::suspendTask(const QString &id) {
Shinya Kitaoka 120a6e
  QString data("suspendTask");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::activateTask(const QString &id) {
Shinya Kitaoka 120a6e
  QString data("activateTask");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::restartTask(const QString &id) {
Shinya Kitaoka 120a6e
  QString data("restartTask");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
otakuto 158f9f
void Controller::getTasks(std::vector<qstring> &tasks) {</qstring>
Shinya Kitaoka 120a6e
  QString data("getTasks@vector");
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // la stringa restituita contiene le informazioni desiderate separate da ","
otakuto 158f9f
  std::vector<qstring> argv;</qstring>
Shinya Kitaoka 120a6e
  extractArgs(reply, argv);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  tasks.clear();
Shinya Kitaoka 120a6e
  std::vector<qstring>::iterator it = argv.begin();</qstring>
Shinya Kitaoka 120a6e
  for (; it != argv.end(); ++it) tasks.push_back(*it);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
otakuto 158f9f
void Controller::getTasks(const QString &parentId,
otakuto 158f9f
                          std::vector<qstring> &tasks) {</qstring>
Shinya Kitaoka 120a6e
  QString data("getTasks@string@vector");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += parentId;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // la stringa restituita contiene le informazioni deiderate separate da ","
otakuto 158f9f
  std::vector<qstring> argv;</qstring>
Shinya Kitaoka 120a6e
  extractArgs(reply, argv);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  tasks.clear();
Shinya Kitaoka 120a6e
  std::vector<qstring>::iterator it = argv.begin();</qstring>
Shinya Kitaoka 120a6e
  for (; it != argv.end(); ++it) tasks.push_back(*it);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::getTasks(const QString &parentId,
otakuto 158f9f
                          std::vector<taskshortinfo> &tasks) {</taskshortinfo>
Shinya Kitaoka 120a6e
  QString data("getTasks@string@vector$TaskShortInfo");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += parentId;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // la stringa restituita contiene le informazioni desiderate separate da ","
otakuto 158f9f
  std::vector<qstring> argv;</qstring>
Shinya Kitaoka 120a6e
  extractArgs(reply, argv);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  tasks.clear();
Shinya Kitaoka 120a6e
  std::vector<qstring>::iterator it = argv.begin();</qstring>
Shinya Kitaoka 120a6e
  for (; it != argv.end(); ++it) {
Shinya Kitaoka 120a6e
    QString id   = *it++;
Shinya Kitaoka 120a6e
    QString name = *it++;
Shinya Kitaoka 120a6e
    TaskState status;
Shinya Kitaoka 120a6e
    status = (TaskState)(*it).toInt();
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
    tasks.push_back(TaskShortInfo(id, name, status));
Shinya Kitaoka 120a6e
  }
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::queryTaskInfo(const QString &id, TFarmTask &task) {
Shinya Kitaoka 120a6e
  QString data("queryTaskInfo_2");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // la stringa restituita contiene le informazioni desiderate separate da ","
otakuto 158f9f
  std::vector<qstring> argv;</qstring>
Shinya Kitaoka 120a6e
  int count = extractArgs(reply, argv);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  if (reply == "") return;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  assert(argv.size() > 15);
Shinya Kitaoka 120a6e
  int incr    = 0;
Shinya Kitaoka 120a6e
  task.m_name = argv[incr++];
Shinya Kitaoka 120a6e
  task.parseCommandLine(argv[incr++]);
Shinya Kitaoka 120a6e
  task.m_priority = argv[incr++].toInt();
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  task.m_user     = argv[incr++];
Shinya Kitaoka 120a6e
  task.m_hostName = argv[incr++];
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  task.m_id       = argv[incr++];
Shinya Kitaoka 120a6e
  task.m_parentId = argv[incr++];
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  task.m_status = (TaskState)argv[incr++].toInt();
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  task.m_server         = argv[incr++];
Shinya Kitaoka 120a6e
  task.m_submissionDate = QDateTime::fromString(argv[incr++]);
Shinya Kitaoka 120a6e
  task.m_startDate      = QDateTime::fromString(argv[incr++]);
Shinya Kitaoka 120a6e
  task.m_completionDate = QDateTime::fromString(argv[incr++]);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  task.m_successfullSteps = argv[incr++].toInt();
Shinya Kitaoka 120a6e
  task.m_failedSteps      = argv[incr++].toInt();
Shinya Kitaoka 120a6e
  task.m_stepCount        = argv[incr++].toInt();
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  if (incr < count) {
Shinya Kitaoka 120a6e
    task.m_platform = (TFarmPlatform)argv[incr++].toInt();
Shinya Kitaoka 120a6e
    int depCount    = 0;
Shinya Kitaoka 120a6e
    depCount        = argv[incr++].toInt();
Shinya Kitaoka 120a6e
    if (depCount > 0) {
Shinya Kitaoka 120a6e
      task.m_dependencies = new TFarmTask::Dependencies;
Shinya Kitaoka 120a6e
      for (int i = 0; i < depCount; ++i) task.m_dependencies->add(argv[incr++]);
Shinya Kitaoka 120a6e
    }
Shinya Kitaoka 120a6e
  }
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::queryTaskShortInfo(const QString &id, QString &parentId,
Shinya Kitaoka 120a6e
                                    QString &name, TaskState &status) {
Shinya Kitaoka 120a6e
  QString data("queryTaskShortInfo");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // la stringa restituita contiene le informazioni desiderate separate da ","
otakuto 158f9f
  std::vector<qstring> argv;</qstring>
Shinya Kitaoka 120a6e
  extractArgs(reply, argv);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  assert(argv.size() == 3);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  parentId = argv[0];
Shinya Kitaoka 120a6e
  name     = argv[1];
Shinya Kitaoka 120a6e
  status   = (TaskState)argv[2].toInt();
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::attachServer(const QString &name, const QString &addr,
Shinya Kitaoka 120a6e
                              int port) {
Shinya Kitaoka 120a6e
  QString data("attachServer");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += name;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += addr;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(port);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::detachServer(const QString &name, const QString &addr,
Shinya Kitaoka 120a6e
                              int port) {
Shinya Kitaoka 120a6e
  QString data("detachServer");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += name;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += addr;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(port);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::taskSubmissionError(const QString &taskId, int errCode) {
Shinya Kitaoka 120a6e
  QString data("taskSubmissionError");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += taskId;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(errCode);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::taskProgress(const QString &taskId, int step, int stepCount,
Shinya Kitaoka 120a6e
                              int frameNumber, FrameState state) {
Shinya Kitaoka 120a6e
  QString data("taskProgress");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += taskId;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(step);
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(stepCount);
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(frameNumber);
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(state);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::taskCompleted(const QString &taskId, int exitCode) {
Shinya Kitaoka 120a6e
  QString data("taskCompleted");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += taskId;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(exitCode);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
otakuto 158f9f
void Controller::getServers(std::vector<serveridentity> &servers) {</serveridentity>
Shinya Kitaoka 120a6e
  QString data("getServers");
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // la stringa restituita contiene le informazioni desiderate separate da ","
otakuto 158f9f
  std::vector<qstring> argv;</qstring>
Shinya Kitaoka 120a6e
  extractArgs(reply, argv);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  servers.clear();
Shinya Kitaoka 120a6e
  std::vector<qstring>::iterator it = argv.begin();</qstring>
Shinya Kitaoka 120a6e
  for (; it != argv.end(); it += 2)
Shinya Kitaoka 120a6e
    servers.push_back(ServerIdentity(*it, *(it + 1)));
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
ServerState Controller::queryServerState2(const QString &name) {
Shinya Kitaoka 120a6e
  QString data("queryServerState2");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += name;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  ServerState serverState = (ServerState)reply.toInt();
Shinya Kitaoka 120a6e
  return serverState;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::queryServerInfo(const QString &id, ServerInfo &info) {
Shinya Kitaoka 120a6e
  QString data("queryServerInfo");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Shinya Kitaoka 120a6e
  if (reply != "") {
Shinya Kitaoka 120a6e
    // la stringa restituita contiene le informazioni desiderate separate da ","
otakuto 158f9f
    std::vector<qstring> argv;</qstring>
Shinya Kitaoka 120a6e
    extractArgs(reply, argv);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
    info.m_name       = argv[0];
Shinya Kitaoka 120a6e
    info.m_ipAddress  = argv[1];
Shinya Kitaoka 120a6e
    info.m_portNumber = argv[2];
Shinya Kitaoka 120a6e
    info.m_state      = (ServerState)argv[3].toInt();
Shinya Kitaoka 120a6e
    info.m_platform   = argv[4];
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
    int cpuCount, totPhysMem, totVirtMem, availPhysMem, availVirtMem;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
    cpuCount             = argv[5].toInt();
Shinya Kitaoka 120a6e
    totPhysMem           = argv[6].toInt();
Shinya Kitaoka 120a6e
    totVirtMem           = argv[7].toInt();
Shinya Kitaoka 120a6e
    availPhysMem         = argv[8].toInt();
Shinya Kitaoka 120a6e
    availVirtMem         = argv[9].toInt();
Shinya Kitaoka 120a6e
    info.m_currentTaskId = argv[10];
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
    info.m_cpuCount     = cpuCount;
Shinya Kitaoka 120a6e
    info.m_totPhysMem   = totPhysMem;
Shinya Kitaoka 120a6e
    info.m_totVirtMem   = totVirtMem;
Shinya Kitaoka 120a6e
    info.m_availPhysMem = availPhysMem;
Shinya Kitaoka 120a6e
    info.m_availVirtMem = availVirtMem;
Shinya Kitaoka 120a6e
  }
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::activateServer(const QString &id) {
Shinya Kitaoka 120a6e
  QString data("activateServer");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void Controller::deactivateServer(const QString &id,
Shinya Kitaoka 120a6e
                                  bool completeRunningTasks) {
Shinya Kitaoka 120a6e
  QString data("deactivateServer");
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += id;
Shinya Kitaoka 120a6e
  data += ",";
Shinya Kitaoka 120a6e
  data += QString::number(completeRunningTasks);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  QString reply = sendToStub(data);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
}  // anonymous namespace
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//==============================================================================
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
TFarmControllerFactory::TFarmControllerFactory() {}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
int TFarmControllerFactory::create(const ControllerData &data,
Shinya Kitaoka 120a6e
                                   TFarmController **controller)
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
{
Shinya Kitaoka 120a6e
  *controller = new Controller(data.m_hostName, data.m_ipAddress, data.m_port);
Shinya Kitaoka 120a6e
  return 0;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
int TFarmControllerFactory::create(const QString &hostname, int port,
Shinya Kitaoka 120a6e
                                   TFarmController **controller) {
Shinya Kitaoka 120a6e
  *controller = new Controller(hostname, "", port);
Shinya Kitaoka 120a6e
  return 0;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void loadControllerData(const TFilePath &fp, ControllerData &data) {
Shinya Kitaoka 120a6e
  Tifstream is(fp);
Shinya Kitaoka 120a6e
  if (!is || !is.good()) {
Shinya Kitaoka 120a6e
    throw TException(L"Unable to get Farm Controller Data (looking for '" +
Shinya Kitaoka 120a6e
                     fp.getWideString() + L"')");
Shinya Kitaoka 120a6e
  }
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  while (!is.eof()) {
Shinya Kitaoka 120a6e
    char line[1024];
Shinya Kitaoka 120a6e
    is.getline(line, 1024);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
    if (line[0] != '#' && QString(line) != "") {
2fc36c
      std::stringstream iss(line);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
      char hostName[512];
Shinya Kitaoka 120a6e
      char ipAddr[80];
Shinya Kitaoka 120a6e
      int port;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
      iss >> hostName >> ipAddr >> port;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
      data.m_hostName  = hostName;
Shinya Kitaoka 120a6e
      data.m_ipAddress = ipAddr;
Shinya Kitaoka 120a6e
      data.m_port      = port;
Shinya Kitaoka 120a6e
      break;
Shinya Kitaoka 120a6e
    }
Shinya Kitaoka 120a6e
  }
Toshihiro Shimizu 890ddd
}