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[]);
47 Engines_MPIContainer_i(int nbproc, int numproc);
49 ~Engines_MPIContainer_i();
51 // Launch a new MPI container from the current container
52 Engines::MPIContainer_ptr start_MPIimpl(const char* ContainerName,
55 // Load a component in current MPI container
56 // synchronous version for process 0
57 Engines::Component_ptr load_impl(const char* nameToRegister,
58 const char* componentName);
59 // shutdown corba server
62 // asynchronous version for other process
63 void SPload_impl(const char* nameToRegister, const char* componentName);
65 // Unload a component from current MPI container
66 // synchronous version for process 0
67 void remove_impl(Engines::Component_ptr component_i);
68 // asynchronous version for other process
69 void SPremove_impl(Engines::Component_ptr component_i);
71 // synchronous version for process 0
72 void finalize_removal();
73 // asynchronous version for other process
74 void SPfinalize_removal();
77 // local version to not duplicate code
78 // called by synchronous and asynchronous version
79 Engines::Component_ptr Lload_impl(const char* nameToRegister,
80 const char* componentName);
81 void Lremove_impl(Engines::Component_ptr component_i);
82 void Lfinalize_removal();