Salome HOME
A patch from Paul RASCLE for: kernel documentation with doxygen, modification on...
[modules/kernel.git] / src / Batch / Batch_BatchManagerCatalog.cxx
1 // Copyright (C) 2005  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
2 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
3 // 
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License as published by the Free Software Foundation; either 
7 // version 2.1 of the License.
8 // 
9 // This library is distributed in the hope that it will be useful 
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU 
12 // Lesser General Public License for more details.
13 //
14 // You should have received a copy of the GNU Lesser General Public  
15 // License along with this library; if not, write to the Free Software 
16 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 //
18 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 //
20 /*
21  * BatchManagerCatalog.cxx : 
22  *
23  * Auteur : Ivan DUTKA-MALEN - EDF R&D
24  * Date   : Septembre 2004
25  * Projet : SALOME 2
26  *
27  */
28
29 #include <string>
30 #include <sstream>
31 #include <map>
32 #include "Batch_BatchManagerCatalog.hxx"
33 #include "Batch_FactBatchManager.hxx"
34 using namespace std;
35
36 namespace Batch {
37
38   pthread_mutex_t BatchManagerCatalog::_mutex = PTHREAD_MUTEX_INITIALIZER;
39   std::map<string, FactBatchManager *> * BatchManagerCatalog::_p_catalog = 0;
40
41   // Constructeur
42   BatchManagerCatalog::BatchManagerCatalog()
43   {
44     // Nothing to do
45   }
46
47   // Destructeur
48   BatchManagerCatalog::~BatchManagerCatalog()
49   {
50     // Nothing to do
51   }
52
53   // Functor
54   FactBatchManager * BatchManagerCatalog::getFactBatchManager(const char * type)
55   {
56     return (* BatchManagerCatalog::_p_catalog)[type];
57   }
58
59   void BatchManagerCatalog::addFactBatchManager(const char * type, FactBatchManager * pFBM)
60   {
61     if (pFBM) { // *** section critique ***
62       pthread_mutex_lock(&_mutex);
63
64       if (! BatchManagerCatalog::_p_catalog) BatchManagerCatalog::_p_catalog = new std::map<string, FactBatchManager *>;
65       (*BatchManagerCatalog::_p_catalog)[type] = pFBM;
66
67       pthread_mutex_unlock(&_mutex);
68     }
69   }
70
71   FactBatchManager * BatchManagerCatalog::operator() (const char * type) const
72   {
73     return BatchManagerCatalog::getFactBatchManager(type);
74   }
75
76   std::map<string, FactBatchManager *> * BatchManagerCatalog::dict() const
77   {
78     return _p_catalog;
79   }
80
81   string BatchManagerCatalog::__repr__() const
82   {
83     ostringstream oss;
84     oss << "<BatchManagerCatalog contains {";
85     string sep;
86     for(std::map<string, FactBatchManager *>::const_iterator it = (*_p_catalog).begin(); it != (*_p_catalog).end(); it++, sep=", ") {
87       oss << sep << "'" << (*it).first << "' : '" << (*it).second->__repr__() << "'";
88     }
89     oss << "}>";
90     return oss.str();
91   }
92
93 }