-// Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
+// Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
-// version 2.1 of the License.
+// version 2.1 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
#include <map>
#include <iostream>
-#ifdef WNT
+#ifdef WIN32
#pragma warning(disable:4251) // Warning DLL Interface ...
#endif
-enum AccessProtocolType {rsh, ssh, srun, pbsdsh, blaunch};
+enum AccessProtocolType {sh, rsh, ssh, srun, pbsdsh, blaunch};
-enum AccessModeType {interactive, batch};
+enum ResourceType {cluster, single_machine};
-enum BatchType {none, pbs, lsf, sge, ssh_batch, ccc, ll, slurm, vishnu};
+enum BatchType {none, pbs, lsf, sge, ccc, ll, slurm, vishnu, oar, coorm};
-enum MpiImplType {nompi, lam, mpich1, mpich2, openmpi, slurmmpi, prun};
+enum MpiImplType {nompi, lam, mpich1, mpich2, openmpi, ompi, slurmmpi, prun};
+
+class RESOURCESMANAGER_EXPORT ResourcesException
+{
+public:
+ const std::string msg;
+
+ ResourcesException(const std::string m) : msg(m) {}
+};
class RESOURCESMANAGER_EXPORT ResourceDataToSort
{
unsigned int GetNumberOfPoints() const;
};
-struct RESOURCESMANAGER_EXPORT ParserResourcesClusterMembersType
+class RESOURCESMANAGER_EXPORT ParserResourcesType
{
- std::string HostName;
- AccessProtocolType Protocol;
- AccessProtocolType ClusterInternalProtocol;
- std::string UserName;
- std::string AppliPath;
- ResourceDataToSort DataForSort;
-};
+public:
+ ParserResourcesType();
+ virtual ~ParserResourcesType();
+
+ std::string getAccessProtocolTypeStr() const;
+ std::string getResourceTypeStr() const;
+ std::string getBatchTypeStr() const;
+ std::string getMpiImplTypeStr() const;
+ std::string getClusterInternalProtocolStr() const;
+ std::string getCanLaunchBatchJobsStr() const;
+ std::string getCanRunContainersStr() const;
+
+ void setAccessProtocolTypeStr(const std::string & protocolTypeStr);
+ void setResourceTypeStr(const std::string & resourceTypeStr);
+ void setBatchTypeStr(const std::string & batchTypeStr);
+ void setMpiImplTypeStr(const std::string & mpiImplTypeStr);
+ void setClusterInternalProtocolStr(const std::string & internalProtocolTypeStr);
+ void setCanLaunchBatchJobsStr(const std::string & canLaunchBatchJobsStr);
+ void setCanRunContainersStr(const std::string & canRunContainersStr);
-struct RESOURCESMANAGER_EXPORT ParserResourcesType
-{
ResourceDataToSort DataForSort;
std::string Name;
std::string HostName;
AccessProtocolType Protocol;
AccessProtocolType ClusterInternalProtocol;
- AccessModeType Mode;
+ ResourceType type;
BatchType Batch;
MpiImplType mpi;
std::string UserName;
std::string batchQueue;
std::string userCommands;
std::string use;
- std::list<ParserResourcesClusterMembersType> ClusterMembersList;
+ std::list<ParserResourcesType> ClusterMembersList;
unsigned int nbOfProc;
- bool is_cluster_head;
+ bool can_launch_batch_jobs;
+ bool can_run_containers;
std::string working_directory;
- void Print();
- void Clear();
+protected:
static std::string protocolToString(AccessProtocolType protocol);
static AccessProtocolType stringToProtocol(const std::string & protocolStr);
- std::string PrintAccessProtocolType() const;
- std::string PrintAccessModeType() const;
- std::string PrintBatchType() const;
- std::string PrintMpiImplType() const;
- std::string PrintClusterInternalProtocol() const;
+ RESOURCESMANAGER_EXPORT friend std::ostream & operator<<(std::ostream &os,
+ const ParserResourcesType &rt);
+
};
typedef std::map<std::string, ParserResourcesType> MapOfParserResourcesType;