1 // SALOME MPIContainer : implemenation of container based on MPI libraries
3 // Copyright (C) 2003 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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
24 // File : MPIContainer_i.hxx
27 #ifndef _SALOME_PCONTAINER_
28 #define _SALOME_PCONTAINER_
30 #include <SALOMEconfig.h>
31 #include CORBA_SERVER_HEADER(SALOME_MPIContainer)
32 #include "SALOME_Container_i.hxx"
33 #include "MPIObject_i.hxx"
35 class Engines_MPIContainer_i : public POA_Engines::MPIContainer,
36 public Engines_Container_i,
42 Engines_MPIContainer_i( int nbproc, int numproc,
44 PortableServer::POA_ptr poa,
46 int argc, char *argv[]);
48 ~Engines_MPIContainer_i();
50 // Launch a new MPI container from the current container
51 Engines::MPIContainer_ptr start_MPIimpl(const char* ContainerName,
54 // Load a component in current MPI container
55 // synchronous version for process 0
56 Engines::Component_ptr load_impl(const char* nameToRegister,
57 const char* componentName);
58 // asynchronous version for other process
59 void SPload_impl(const char* nameToRegister, const char* componentName);
61 // Unload a component from current MPI container
62 // synchronous version for process 0
63 void remove_impl(Engines::Component_ptr component_i);
64 // asynchronous version for other process
65 void SPremove_impl(Engines::Component_ptr component_i);
67 // synchronous version for process 0
68 void finalize_removal();
69 // asynchronous version for other process
70 void SPfinalize_removal();
73 // local version to not duplicate code
74 // called by synchronous and asynchronous version
75 Engines::Component_ptr Lload_impl(const char* nameToRegister,
76 const char* componentName);
77 void Lremove_impl(Engines::Component_ptr component_i);
78 void Lfinalize_removal();