1 // Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
25 * Auteur : Ivan DUTKA-MALEN - EDF R&D
26 * Date : Septembre 2003
40 //#include "MEDMEM_STRING.hxx"
41 #include "Batch_Job.hxx"
42 #include "Batch_JobId.hxx"
43 #include "Batch_JobInfo.hxx"
44 #include "Batch_InvalidArgumentException.hxx"
45 #include "Batch_FactBatchManager.hxx"
46 #include "Batch_BatchManager.hxx"
52 // BatchManager::BatchManager(string host) throw(InvalidArgumentException) : _hostname(host), jobid_map()
54 // // On verifie que le hostname est correct
55 // if (!gethostbyname(_hostname.c_str())) { // hostname unknown from network
56 // string msg = "hostname \"";
58 // msg += "\" unknown from the network";
59 // throw InvalidArgumentException(msg.c_str());
62 BatchManager::BatchManager(const FactBatchManager * parent, const char * host) throw(InvalidArgumentException) : _hostname(host), jobid_map(), _parent(parent)
66 WSAStartup(MAKEWORD(2, 2), &wsaData); // Initialize Winsock
69 // On verifie que le hostname est correct
70 struct hostent* res = gethostbyname(_hostname.c_str());
73 WSACleanup(); // Finalize Winsock
76 if (!res) { // hostname unknown from network
77 string msg = "hostname \"";
79 msg += "\" unknown from the network";
80 throw InvalidArgumentException(msg.c_str());
85 BatchManager::~BatchManager()
90 string BatchManager::__repr__() const
93 oss << "<BatchManager of type '" << (_parent ? _parent->getType() : "unknown (no factory)") << "' connected to server '" << _hostname << "'>";
97 // Recupere le l'identifiant d'un job deja soumis au BatchManager
98 // const JobId BatchManager::getJobIdByReference(const string & ref)
100 // return JobId(this, ref);
102 const JobId BatchManager::getJobIdByReference(const char * ref)
104 return JobId(this, ref);
107 // // Methode pour le controle des jobs : soumet un job au gestionnaire
108 // const JobId BatchManager::submitJob(const Job & job)
110 // static int idx = 0;
111 // //MEDMEM::STRING sst;
112 // ostringstream sst;
113 // sst << "Jobid_" << idx++;
114 // JobId id(this, sst.str());
118 // // Methode pour le controle des jobs : retire un job du gestionnaire
119 // void BatchManager::deleteJob(const JobId & jobid)
124 // // Methode pour le controle des jobs : suspend un job en file d'attente
125 // void BatchManager::holdJob(const JobId & jobid)
130 // // Methode pour le controle des jobs : relache un job suspendu
131 // void BatchManager::releaseJob(const JobId & jobid)
136 // // Methode pour le controle des jobs : modifie un job en file d'attente
137 // void BatchManager::alterJob(const JobId & jobid, const Parametre & param, const Environnement & env)
142 // // Methode pour le controle des jobs : modifie un job en file d'attente
143 // void BatchManager::alterJob(const JobId & jobid, const Parametre & param)
148 // // Methode pour le controle des jobs : modifie un job en file d'attente
149 // void BatchManager::alterJob(const JobId & jobid, const Environnement & env)
154 // // Methode pour le controle des jobs : renvoie l'etat du job
155 // JobInfo BatchManager::queryJob(const JobId & jobid)