1 // Copyright (C) 2007-2011 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
23 * Batch_ParameterTypeMap.cxx :
25 * Auteur : Renaud Barate - EDF R&D
33 #include "Batch_Constants.hxx"
34 #include "Batch_InvalidKeyException.hxx"
35 #include "Batch_ParameterTypeMap.hxx"
42 * The values of this type map contain the type of the parameters and the maximum
43 * number of items in the corresponding Versatile object (0 means any number).
45 ParameterTypeMap::ParameterTypeMap()
47 // Don't use the string constants in this constructor because they might be uninitialized
48 addParameter("ACCOUNT", STRING, 1);
49 addParameter("ARGUMENTS", STRING, 0);
50 addParameter("CHECKPOINT", LONG, 1);
51 addParameter("CKPTINTERVAL", LONG, 1);
52 addParameter("CREATIONTIME", LONG, 1);
53 addParameter("EGROUP", STRING, 1);
54 addParameter("ELIGIBLETIME", LONG, 1);
55 addParameter("ENDTIME", LONG, 1);
56 addParameter("EUSER", STRING, 1);
57 addParameter("EXECUTABLE", STRING, 1);
58 addParameter("EXECUTIONHOST", STRING, 0);
59 addParameter("EXITCODE", LONG, 1);
60 addParameter("HOLD", LONG, 1);
61 addParameter("ID", STRING, 1);
62 addParameter("INFILE", COUPLE, 0);
63 addParameter("MAIL", STRING, 1);
64 addParameter("MAXCPUTIME", LONG, 1);
65 addParameter("MAXDISKSIZE", LONG, 1);
66 addParameter("MAXRAMSIZE", LONG, 1);
67 addParameter("MAXWALLTIME", LONG, 1);
68 addParameter("MODIFICATIONTIME", LONG, 1);
69 addParameter("NAME", STRING, 1);
70 addParameter("NBPROC", LONG, 1);
71 addParameter("OUTFILE", COUPLE, 0);
72 addParameter("PID", LONG, 1);
73 addParameter("QUEUE", STRING, 1);
74 addParameter("QUEUEDTIME", LONG, 1);
75 addParameter("SERVER", STRING, 1);
76 addParameter("STARTTIME", LONG, 1);
77 addParameter("STATE", STRING, 1);
78 addParameter("TEXT", STRING, 1);
79 addParameter("TMPDIR", STRING, 1);
80 addParameter("USEDCPUTIME", LONG, 1);
81 addParameter("USEDDISKSIZE", LONG, 1);
82 addParameter("USEDRAMSIZE", LONG, 1);
83 addParameter("USEDWALLTIME", LONG, 1);
84 addParameter("USER", STRING, 1);
85 addParameter("WORKDIR", STRING, 1);
86 addParameter("HOMEDIR", STRING, 1);
87 addParameter("EXCLUSIVE", BOOL, 1);
90 ParameterTypeMap::~ParameterTypeMap()
95 * Returns the ParameterTypeMap singleton.
96 * We use the construct-on-first-use idiom here because otherwise there could be a problem with
97 * the initialization order between the factory singletons and this type map. Note that since the
98 * destructors do not depend on the other objects, the order is not important for destruction.
100 ParameterTypeMap& ParameterTypeMap::getInstance () {
101 static ParameterTypeMap instance;
105 bool ParameterTypeMap::hasKey(const string & key) const
107 return (_map.find(key) != _map.end());
110 void ParameterTypeMap::addParameter(const std::string & key, DiscriminatorType type, int maxelem)
112 if (hasKey(key)) throw InvalidKeyException(key + " is already present in type map");
113 _map[key].type = type;
114 _map[key].maxelem = maxelem;
117 Versatile ParameterTypeMap::createVersatile(const std::string & parameterName)
119 map<string, ParameterType>::const_iterator it = _map.find(parameterName);
120 if (it == _map.end()) throw InvalidKeyException(parameterName);
121 return Versatile(it->second.type, it->second.maxelem, parameterName);