1 // Copyright (C) 2005 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
2 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
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.
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.
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
18 // See http://www.salome-platform.org/
20 //=============================================================================
21 // File : TestMPIComponentEngine.cxx
22 // Created : mer jui 4 12:28:26 CEST 2003
23 // Author : Bernard SECHER, 2003
25 // Copyright : CEA 2003
27 //=============================================================================
30 #include "utilities.h"
31 #include "TestMPIComponentEngine.hxx"
34 TestMPIComponentEngine::TestMPIComponentEngine(int nbproc, int numproc,
36 PortableServer::POA_ptr poa,
37 PortableServer::ObjectId * contId,
38 const char *instanceName,
39 const char *interfaceName,
41 Engines_Component_i(orb, poa, contId, instanceName, interfaceName,true,regist), MPIObject_i(nbproc,numproc)
43 MESSAGE("activate object")
45 _id = _poa->reference_to_id(_thisObj->_this());
48 TestMPIComponentEngine::TestMPIComponentEngine(): Engines_Component_i(), MPIObject_i()
52 TestMPIComponentEngine::~TestMPIComponentEngine()
56 void TestMPIComponentEngine::Coucou(CORBA::Long L)
59 for(int ip=1;ip<_nbproc;ip++)
60 Engines::TestMPIComponent::_narrow((*_tior)[ip])->SPCoucou(L);
64 void TestMPIComponentEngine::SPCoucou(CORBA::Long L)
66 BEGIN_OF("[" << _numproc << "] TestMPIComponentEngine::Coucou()");
67 MESSAGE("[" << _numproc << "] TestMPIComponentEngine : L = " << L);
68 END_OF("[" << _numproc << "] TestMPIComponentEngine::Coucou()");
69 MPI_Barrier(MPI_COMM_WORLD);
74 PortableServer::ObjectId * TestMPIComponentEngine_factory(
75 int nbproc, int numproc,
77 PortableServer::POA_ptr poa,
78 PortableServer::ObjectId * contId,
79 const char *instanceName,
80 const char *interfaceName)
83 TestMPIComponentEngine * myTestMPIComponent;
84 MESSAGE("[" << numproc << "] PortableServer::ObjectId * TestMPIComponentEngine_factory()");
85 SCRUTE(interfaceName);
92 = new TestMPIComponentEngine(nbproc,numproc,orb, poa, contId, instanceName, interfaceName,regist);
93 return myTestMPIComponent->getId() ;