Salome HOME
Join modifications from branch BR_DEBUG_3_2_0b1
[samples/component.git] / src / DivComponent / DivComponent.cxx
1 //  SuperVisionTest DivComponent : example of component that devides two numbers
2 //
3 //  Copyright (C) 2003  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. 
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 //
24 //  File   : DivComponentEngine.cxx
25 //  Author : MARC TAJCHMAN, CEA
26 //  Module : SuperVisionTest
27
28 #include <stdio.h>
29 #include <unistd.h>
30 #include <fstream>
31 #include <sstream>
32 #include <string>
33
34 //#include "utilities.h"
35 #include "DivComponent.hxx"
36
37 using namespace std;
38
39 DivComponentEngine::DivComponentEngine( CORBA::ORB_ptr orb,
40                                     PortableServer::POA_ptr poa,
41                                     PortableServer::ObjectId * contId, 
42                                     const char *instanceName,
43                                     const char *interfaceName) :
44   Engines_Component_i(orb, poa, contId, instanceName, interfaceName,1,true)
45 {
46 //  MESSAGE("DivComponentEngine::DivComponentEngine activate object instanceName("
47 //          << instanceName << ") interfaceName(" << interfaceName << ")" )
48   _thisObj = this ;
49   _id = _poa->activate_object(_thisObj);
50   _nexec = 0 ;
51 }
52
53 DivComponentEngine::DivComponentEngine()
54 {
55 }
56
57 DivComponentEngine::~DivComponentEngine()
58 {
59 }
60
61 void DivComponentEngine::Div( double x , double y , double & z ) {
62   beginService( " DivComponentEngine::Div" );
63   z = x / y ;
64   int S;
65   
66   sendMessage(NOTIF_STEP, "Div is Computing");
67 //  S = 1+(int) (15.0*rand()/(RAND_MAX+1.0));
68   S = 5 ;
69   while ( S ) {
70     S = sleep(S);
71   }
72   sendMessage(NOTIF_TRACE, "Div is Much More Difficult Operation");
73   MESSAGE("DivComponentEngine::Div( " <<  x << " , " << y << " , " << z
74        << " ) after " << S << " seconds" )
75   endService( " DivComponentEngine::Div"  );
76 }
77
78 extern "C"
79 {
80   PortableServer::ObjectId * DivComponentEngine_factory
81      (CORBA::ORB_ptr orb,
82       PortableServer::POA_ptr poa, 
83       PortableServer::ObjectId * contId,
84       const char *instanceName,
85       const char *interfaceName)
86   {
87     MESSAGE("DivComponentEngine_factory DivComponentEngine ("
88             << instanceName << "," << interfaceName << ")");
89     DivComponentEngine * myDivComponent 
90       = new DivComponentEngine(orb, poa, contId, instanceName, interfaceName);
91     return myDivComponent->getId() ;
92   }
93 }
94
95