1 // Copyright (C) 2007-2015 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, or (at your option) any later version.
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 * BatchManagerCatalog.cxx :
25 * Auteur : Ivan DUTKA-MALEN - EDF R&D
26 * Date : Septembre 2004
28 * Modified by Renaud Barate, April 2009
35 #include "BatchManagerCatalog.hxx"
36 #include "FactBatchManager.hxx"
42 BatchManagerCatalog::BatchManagerCatalog()
44 pthread_mutex_init(&_mutex, NULL);
48 BatchManagerCatalog::~BatchManagerCatalog()
50 pthread_mutex_destroy(&_mutex);
54 * Returns the catalog singleton.
55 * We use the construct-on-first-use idiom here because otherwise there could be a problem with
56 * the initialization order between the factory singletons and this catalog. Note that since the
57 * destructors do not depend on the other objects, the order is not important for destruction.
59 BatchManagerCatalog& BatchManagerCatalog::getInstance () {
60 static BatchManagerCatalog instance;
64 void BatchManagerCatalog::addFactBatchManager(const char * type, FactBatchManager * pFBM)
66 if (pFBM) { // *** section critique ***
67 pthread_mutex_lock(&_mutex);
68 _catalog[type] = pFBM;
69 pthread_mutex_unlock(&_mutex);
73 bool BatchManagerCatalog::hasFactBatchManager(const char * type)
75 pthread_mutex_lock(&_mutex);
76 bool result = (_catalog.find(type) != _catalog.end());
77 pthread_mutex_unlock(&_mutex);
82 FactBatchManager * BatchManagerCatalog::operator() (const char * type)
84 FactBatchManager * result = NULL;
85 pthread_mutex_lock(&_mutex);
86 if (_catalog.find(type) != _catalog.end()) result = _catalog[type];
87 pthread_mutex_unlock(&_mutex);
91 std::map<string, FactBatchManager *> * BatchManagerCatalog::dict()
96 string BatchManagerCatalog::__repr__() const
99 oss << "<BatchManagerCatalog contains {";
101 for(std::map<string, FactBatchManager *>::const_iterator it = _catalog.begin(); it != _catalog.end(); it++, sep=", ") {
102 oss << sep << "'" << (*it).first << "' : '" << (*it).second->__repr__() << "'";