Salome HOME
Copyright update 2021
[tools/libbatch.git] / src / Core / BatchManagerCatalog.cxx
1 // Copyright (C) 2007-2021  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
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.
10 //
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.
15 //
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
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 /*
23  * BatchManagerCatalog.cxx :
24  *
25  * Auteur : Ivan DUTKA-MALEN - EDF R&D
26  * Date   : Septembre 2004
27  * Projet : SALOME 2
28  * Modified by Renaud Barate, April 2009
29  *
30  */
31
32 #include <string>
33 #include <sstream>
34 #include <map>
35 #include "BatchManagerCatalog.hxx"
36 #include "FactBatchManager.hxx"
37 using namespace std;
38
39 namespace Batch {
40
41   // Constructeur
42   BatchManagerCatalog::BatchManagerCatalog()
43   {
44     pthread_mutex_init(&_mutex, NULL);
45   }
46
47   // Destructeur
48   BatchManagerCatalog::~BatchManagerCatalog()
49   {
50     pthread_mutex_destroy(&_mutex);
51   }
52
53   /**
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.
58    */
59   BatchManagerCatalog& BatchManagerCatalog::getInstance () {
60     static BatchManagerCatalog instance;
61     return instance;
62   }
63
64   void BatchManagerCatalog::addFactBatchManager(const char * type, FactBatchManager * pFBM)
65   {
66     if (pFBM) { // *** section critique ***
67       pthread_mutex_lock(&_mutex);
68       _catalog[type] = pFBM;
69       pthread_mutex_unlock(&_mutex);
70     }
71   }
72
73   bool BatchManagerCatalog::hasFactBatchManager(const char * type)
74   {
75     pthread_mutex_lock(&_mutex);
76     bool result = (_catalog.find(type) != _catalog.end());
77     pthread_mutex_unlock(&_mutex);
78     return result;
79   }
80
81   // Functor
82   FactBatchManager * BatchManagerCatalog::operator() (const char * type)
83   {
84     FactBatchManager * result = NULL;
85     pthread_mutex_lock(&_mutex);
86     if (_catalog.find(type) != _catalog.end()) result = _catalog[type];
87     pthread_mutex_unlock(&_mutex);
88     return result;
89   }
90
91   std::map<string, FactBatchManager *> * BatchManagerCatalog::dict()
92   {
93     return &_catalog;
94   }
95
96   string BatchManagerCatalog::__repr__() const
97   {
98     ostringstream oss;
99     oss << "<BatchManagerCatalog contains {";
100     string sep;
101     for(std::map<string, FactBatchManager *>::const_iterator it = _catalog.begin(); it != _catalog.end(); it++, sep=", ") {
102       oss << sep << "'" << (*it).first << "' : '" << (*it).second->__repr__() << "'";
103     }
104     oss << "}>";
105     return oss.str();
106   }
107
108 }