Salome HOME
SALOME PAL V1_4_1
[modules/smesh.git] / src / StdMeshers_I / StdMeshers_NumberOfSegments_i.cxx
1 //  SMESH SMESH_I : idl implementation based on 'SMESH' unit's calsses
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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org 
21 //
22 //
23 //
24 //  File   : StdMeshers_NumberOfSegments_i.cxx
25 //           Moved here from SMESH_NumberOfSegments_i.cxx
26 //  Author : Paul RASCLE, EDF
27 //  Module : SMESH
28 //  $Header$
29
30 using namespace std;
31 #include "StdMeshers_NumberOfSegments_i.hxx"
32 #include "SMESH_Gen.hxx"
33
34 #include "Utils_CorbaException.hxx"
35 #include "utilities.h"
36
37 //=============================================================================
38 /*!
39  *  StdMeshers_NumberOfSegments_i::StdMeshers_NumberOfSegments_i
40  *
41  *  Constructor
42  */
43 //=============================================================================
44
45 StdMeshers_NumberOfSegments_i::StdMeshers_NumberOfSegments_i( PortableServer::POA_ptr thePOA,
46                                                     int                     theStudyId,
47                                                     ::SMESH_Gen*            theGenImpl )
48      : SALOME::GenericObj_i( thePOA ), 
49        SMESH_Hypothesis_i( thePOA )
50 {
51   MESSAGE( "StdMeshers_NumberOfSegments_i::StdMeshers_NumberOfSegments_i" );
52   myBaseImpl = new ::StdMeshers_NumberOfSegments( theGenImpl->GetANewId(),
53                                              theStudyId,
54                                              theGenImpl );
55 }
56
57 //=============================================================================
58 /*!
59  *  StdMeshers_NumberOfSegments_i::~StdMeshers_NumberOfSegments_i
60  *
61  *  Destructor
62  */
63 //=============================================================================
64
65 StdMeshers_NumberOfSegments_i::~StdMeshers_NumberOfSegments_i()
66 {
67   MESSAGE( "StdMeshers_NumberOfSegments_i::~StdMeshers_NumberOfSegments_i" );
68 }
69
70 //=============================================================================
71 /*!
72  *  StdMeshers_NumberOfSegments_i::SetNumberOfSegments
73  *
74  *  Set number of segments
75  */
76 //=============================================================================
77
78 void StdMeshers_NumberOfSegments_i::SetNumberOfSegments( CORBA::Long theSegmentsNumber )
79      throw ( SALOME::SALOME_Exception )
80 {
81   MESSAGE( "StdMeshers_NumberOfSegments_i::SetNumberOfSegments" );
82   ASSERT( myBaseImpl );
83   try {
84     this->GetImpl()->SetNumberOfSegments( theSegmentsNumber );
85   }
86   catch (SALOME_Exception& S_ex) {
87     THROW_SALOME_CORBA_EXCEPTION( S_ex.what(),
88                                   SALOME::BAD_PARAM );
89   }
90 }
91
92 //=============================================================================
93 /*!
94  *  StdMeshers_NumberOfSegments_i::GetNumberOfSegments
95  *
96  *  Get number of segments
97  */
98 //=============================================================================
99
100 CORBA::Long StdMeshers_NumberOfSegments_i::GetNumberOfSegments()
101 {
102   MESSAGE( "StdMeshers_NumberOfSegments_i::GetNumberOfSegments" );
103   ASSERT( myBaseImpl );
104   return this->GetImpl()->GetNumberOfSegments();
105 }
106
107 //=============================================================================
108 /*!
109  *  StdMeshers_NumberOfSegments_i::SetScaleFactor
110  *
111  *  Set scalar factor
112  */
113 //=============================================================================
114
115 void StdMeshers_NumberOfSegments_i::SetScaleFactor( CORBA::Double theScaleFactor )
116      throw ( SALOME::SALOME_Exception )
117 {
118   MESSAGE( "StdMeshers_NumberOfSegments_i::SetScaleFactor" );
119   ASSERT( myBaseImpl );
120   try {
121     this->GetImpl()->SetScaleFactor( theScaleFactor );
122   }
123   catch ( SALOME_Exception& S_ex ) {
124     THROW_SALOME_CORBA_EXCEPTION( S_ex.what(),
125                                   SALOME::BAD_PARAM );
126   }
127 }
128
129 //=============================================================================
130 /*!
131  *  StdMeshers_NumberOfSegments_i::GetScaleFactor
132  *
133  *  Get scalar factor
134  */
135 //=============================================================================
136
137 CORBA::Double StdMeshers_NumberOfSegments_i::GetScaleFactor()
138 {
139   MESSAGE( "StdMeshers_NumberOfSegments_i::GetScaleFactor" );
140   ASSERT( myBaseImpl );
141   return this->GetImpl()->GetScaleFactor();
142 }
143
144 //=============================================================================
145 /*!
146  *  StdMeshers_NumberOfSegments_i::GetImpl
147  *
148  *  Get implementation
149  */
150 //=============================================================================
151
152 ::StdMeshers_NumberOfSegments* StdMeshers_NumberOfSegments_i::GetImpl()
153 {
154   MESSAGE( "StdMeshers_NumberOfSegments_i::GetImpl" );
155   return ( ::StdMeshers_NumberOfSegments* )myBaseImpl;
156 }
157