Version: 9.15.0
SALOME_ParallelComponent_i.hxx
Go to the documentation of this file.
1 // Copyright (C) 2007-2025 CEA, EDF, 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 // SALOME_ParallelComponent : implementation of container and engine for Parallel Kernel
24 // File : SALOME_ParallelComponent_i.hxx
25 // Author : Andr� RIBES, EDF
26 // Author : Paul RASCLE, EDF - MARC TAJCHMAN, CEA
27 //
28 #ifndef _SALOME_PARALLEL_COMPONENT_I_HXX_
29 #define _SALOME_PARALLEL_COMPONENT_I_HXX_
30 
31 #include <iostream>
32 #include <signal.h>
33 #include <stdlib.h>
34 #ifndef WIN32
35 #include <unistd.h>
36 #endif
37 #include <sys/types.h>
38 #include <string>
39 #include <map>
40 #include <SALOMEconfig.h>
41 
42 #include "SALOME_PACOExtensionPaCO_Engines_Parallel_Component_server.hxx"
43 
44 #include "NOTIFICATION.hxx"
45 #include "RegistryConnexion.hxx"
47 
49 
50 #ifdef WIN32
51 # if defined CONTAINER_EXPORTS || defined SalomeParallelContainer_EXPORTS
52 # define CONTAINER_EXPORT __declspec( dllexport )
53 # else
54 # define CONTAINER_EXPORT __declspec( dllimport )
55 # endif
56 #else
57 # define CONTAINER_EXPORT
58 #endif
59 
61  public virtual Engines::Parallel_Component_serv,
62  public virtual PortableServer::RefCountServantBase
63 {
64 public:
65  Engines_Parallel_Component_i(CORBA::ORB_ptr orb, char * ior, int rank,
66  PortableServer::POA_ptr poa,
67  PortableServer::ObjectId * contId,
68  const char *instanceName,
69  const char *interfaceName,
70  bool notif = false,
71  bool regist = true);
72 
74 
75  // --- CORBA methods
76 
77  char* instanceName();
78  char* interfaceName();
79 
80  void ping();
81  void destroy();
82 
83  Engines::Container_ptr GetContainerRef();
84 
85  void setProperties(const Engines::FieldsDict& dico);
86  Engines::FieldsDict* getProperties();
87 
88  void Names( const char * graphName , const char * nodeName ) ;
89  bool Kill_impl();
90  bool Stop_impl();
91  bool Suspend_impl();
92  bool Resume_impl();
93  CORBA::Long CpuUsed_impl() ;
94 
95  virtual Engines::TMPFile* DumpPython(CORBA::Boolean isPublished,
96  CORBA::Boolean isMultiFile,
97  CORBA::Boolean& isValidScript);
98 
99  // CORBA operations for Salome_file
100  virtual Engines::Salome_file_ptr getInputFileToService(const char* service_name,
101  const char* Salome_file_name);
102  virtual Engines::Salome_file_ptr getOutputFileToService(const char* service_name,
103  const char* Salome_file_name);
104 
105  virtual void checkInputFilesToService(const char* service_name);
106  virtual Engines::Salome_file_ptr setInputFileToService(const char* service_name,
107  const char* Salome_file_name);
108 
109  virtual void checkOutputFilesToService(const char* service_name);
110  virtual Engines::Salome_file_ptr setOutputFileToService(const char* service_name,
111  const char* Salome_file_name);
112 
113  void send_parallel_proxy_object(CORBA::Object_ptr proxy_ref);
114 
115  // Object information
116  virtual bool hasObjectInfo() { return false; }
117  virtual char* getObjectInfo(const char* entry) { return ""; }
118 
119  // --- local C++ methods
120 
121  PortableServer::ObjectId * getId();
122  Engines_Parallel_Container_i *GetContainerPtr();
123 
124  static bool isMultiInstance();
125  static std::string GetDynLibraryName(const char *componentName);
126 
127  void beginService(const char *serviceName);
128  void endService(const char *serviceName);
129  void sendMessage(const char *event_type, const char *message);
130  char * graphName() ;
131  char * nodeName() ;
132  bool Killer( pthread_t ThreadId , int signum );
133  void SetCurCpu() ;
134  long CpuUsed() ;
135  void CancelThread();
136 
137  void wait_parallel_object_proxy();
138  char * get_parallel_proxy_object();
139 
140  virtual void configureSalome_file(std::string service_name,
141  std::string file_port_name,
142  Engines::Parallel_Salome_file_proxy_impl * file);
143 
144 protected:
145  static bool _isMultiInstance;
146 
147  std::string _instanceName ;
148  std::string _interfaceName ;
149 
150  CORBA::ORB_var _orb;
151  PortableServer::POA_var _poa;
152  PortableServer::ObjectId * _id;
153  PortableServer::ObjectId * _contId;
157  std::map<std::string,CORBA::Any>_fieldsDict;
158 
159  // Map Salome_file_name to Parallel_Salome_file*
160  typedef std::map<std::string, Parallel_Salome_file_i*> _t_Salome_file_map;
161  typedef std::map<std::string, Engines::Parallel_Salome_file_proxy_impl*> _t_Proxy_Salome_file_map;
162  typedef std::map<std::string, std::string> _t_IOR_Proxy_Salome_file_map;
163 
164  // Map Service_name to _Salome_file_map
165  typedef std::map<std::string, Engines_Parallel_Component_i::_t_Salome_file_map*> _t_Service_file_map;
166  typedef std::map<std::string, Engines_Parallel_Component_i::_t_Proxy_Salome_file_map*> _t_Proxy_Service_file_map;
167  typedef std::map<std::string, Engines_Parallel_Component_i::_t_IOR_Proxy_Salome_file_map*> _t_IOR_Proxy_Service_file_map;
168 
171  _t_Service_file_map::iterator _Service_file_map_it;
172  _t_Salome_file_map::iterator _Salome_file_map_it;
173 
176  _t_Proxy_Service_file_map::iterator _Proxy_Service_file_map_it;
177  _t_Proxy_Salome_file_map::iterator _Proxy_Salome_file_map_it;
178 
181  _t_IOR_Proxy_Service_file_map::iterator _IOR_Proxy_Service_file_map_it;
182  _t_IOR_Proxy_Salome_file_map::iterator _IOR_Proxy_Salome_file_map_it;
183 
184  std::string _serviceName ;
185  std::string _graphName ;
186  std::string _nodeName ;
187 
188  pthread_mutex_t * deploy_mutex;
189  char * _proxy;
190 
191 private:
192 #ifndef WIN32
193  pthread_t _ThreadId ;
194 #else
195  pthread_t* _ThreadId ;
196 #endif
197  long _StartUsed ;
199  bool _Executed ;
202 };
203 
204 #endif
#define CONTAINER_EXPORT
Definition: SALOME_ParallelComponent_i.hxx:57
Definition: SALOME_ParallelComponent_i.hxx:63
bool _CanceledThread
Definition: SALOME_ParallelComponent_i.hxx:200
_t_IOR_Proxy_Salome_file_map::iterator _IOR_Proxy_Salome_file_map_it
Definition: SALOME_ParallelComponent_i.hxx:182
std::map< std::string, Engines::Parallel_Salome_file_proxy_impl * > _t_Proxy_Salome_file_map
Definition: SALOME_ParallelComponent_i.hxx:161
_t_Proxy_Service_file_map _Proxy_Output_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:175
std::map< std::string, Engines_Parallel_Component_i::_t_Salome_file_map * > _t_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:165
pthread_mutex_t * deploy_mutex
Definition: SALOME_ParallelComponent_i.hxx:188
long _StartUsed
Definition: SALOME_ParallelComponent_i.hxx:197
RegistryConnexion * _myConnexionToRegistry
Definition: SALOME_ParallelComponent_i.hxx:155
_t_IOR_Proxy_Service_file_map _IOR_Proxy_Output_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:180
virtual char * getObjectInfo(const char *entry)
Definition: SALOME_ParallelComponent_i.hxx:117
_t_Proxy_Service_file_map _Proxy_Input_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:174
pthread_t _ThreadId
Definition: SALOME_ParallelComponent_i.hxx:193
std::map< std::string, std::string > _t_IOR_Proxy_Salome_file_map
Definition: SALOME_ParallelComponent_i.hxx:162
PortableServer::ObjectId * _contId
Definition: SALOME_ParallelComponent_i.hxx:153
_t_Proxy_Service_file_map::iterator _Proxy_Service_file_map_it
Definition: SALOME_ParallelComponent_i.hxx:176
static bool _isMultiInstance
Definition: SALOME_ParallelComponent_i.hxx:145
std::map< std::string, Engines_Parallel_Component_i::_t_IOR_Proxy_Salome_file_map * > _t_IOR_Proxy_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:167
std::map< std::string, Parallel_Salome_file_i * > _t_Salome_file_map
Definition: SALOME_ParallelComponent_i.hxx:160
_t_Service_file_map::iterator _Service_file_map_it
Definition: SALOME_ParallelComponent_i.hxx:171
std::string _instanceName
Definition: SALOME_ParallelComponent_i.hxx:147
std::string _graphName
Definition: SALOME_ParallelComponent_i.hxx:185
_t_Proxy_Salome_file_map::iterator _Proxy_Salome_file_map_it
Definition: SALOME_ParallelComponent_i.hxx:177
Engines_Parallel_Component_i * _thisObj
Definition: SALOME_ParallelComponent_i.hxx:154
PortableServer::POA_var _poa
Definition: SALOME_ParallelComponent_i.hxx:151
_t_IOR_Proxy_Service_file_map::iterator _IOR_Proxy_Service_file_map_it
Definition: SALOME_ParallelComponent_i.hxx:181
bool _destroyed
Definition: SALOME_ParallelComponent_i.hxx:201
std::map< std::string, CORBA::Any > _fieldsDict
Definition: SALOME_ParallelComponent_i.hxx:157
_t_Service_file_map _Input_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:169
NOTIFICATION_Supplier * _notifSupplier
Definition: SALOME_ParallelComponent_i.hxx:156
std::map< std::string, Engines_Parallel_Component_i::_t_Proxy_Salome_file_map * > _t_Proxy_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:166
std::string _interfaceName
Definition: SALOME_ParallelComponent_i.hxx:148
_t_Salome_file_map::iterator _Salome_file_map_it
Definition: SALOME_ParallelComponent_i.hxx:172
_t_IOR_Proxy_Service_file_map _IOR_Proxy_Input_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:179
char * _proxy
Definition: SALOME_ParallelComponent_i.hxx:189
CORBA::ORB_var _orb
Definition: SALOME_ParallelComponent_i.hxx:150
std::string _serviceName
Definition: SALOME_ParallelComponent_i.hxx:184
PortableServer::ObjectId * _id
Definition: SALOME_ParallelComponent_i.hxx:152
bool _Executed
Definition: SALOME_ParallelComponent_i.hxx:199
_t_Service_file_map _Output_Service_file_map
Definition: SALOME_ParallelComponent_i.hxx:170
long _ThreadCpuUsed
Definition: SALOME_ParallelComponent_i.hxx:198
virtual bool hasObjectInfo()
Definition: SALOME_ParallelComponent_i.hxx:116
std::string _nodeName
Definition: SALOME_ParallelComponent_i.hxx:186
C++ implementation of Engines::Container interface for parallel container implemented with PaCO++.
Definition: SALOME_ParallelContainer_i.hxx:60
Definition: NOTIFICATION_Supplier.hxx:37
Definition: RegistryConnexion.hxx:45
sequence< KeyValuePair > FieldsDict
Definition: SALOME_Component.idl:65
sequence< octet > TMPFile
A byte stream which is used for binary data transfer between different components.
Definition: SALOME_Component.idl:50
poa
Definition: SALOME_ContainerPy.py:377
orb
Definition: salome.py:122