1 // Copyright (C) 2011-2012 CEA/DEN, EDF R&D
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License.
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // Lesser General Public License for more details.
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
20 // L'ordre de description des fonctions est le meme dans tous les fichiers
21 // HOMARD_aaaa.idl, HOMARD_aaaa.hxx, HOMARD_aaaa.cxx, HOMARD_aaaa_i.hxx, HOMARD_aaaa_i.cxx :
22 // 1. Les generalites : Name, Delete, DumpPython, Dump, Restore
23 // 2. Les caracteristiques
24 // 3. Le lien avec les autres structures
26 // Quand les 2 fonctions Setxxx et Getxxx sont presentes, Setxxx est decrit en premier
28 #include "HOMARD_Boundary_i.hxx"
29 #include "HOMARD_Gen_i.hxx"
30 #include "HOMARD_Boundary.hxx"
31 #include "HOMARD_DriverTools.hxx"
33 #include "utilities.h"
35 //=============================================================================
37 * standard constructor
39 //=============================================================================
40 HOMARD_Boundary_i::HOMARD_Boundary_i()
42 MESSAGE( "Default constructor, not for use" );
46 //=============================================================================
48 * standard constructor
50 //=============================================================================
51 HOMARD_Boundary_i::HOMARD_Boundary_i( CORBA::ORB_ptr orb,
52 HOMARD::HOMARD_Gen_var engine )
54 MESSAGE( "HOMARD_Boundary_i" );
57 myHomardBoundary = new ::HOMARD_Boundary();
58 ASSERT( myHomardBoundary );
60 //=============================================================================
64 //=============================================================================
66 HOMARD_Boundary_i::~HOMARD_Boundary_i()
69 //=============================================================================
70 //=============================================================================
72 //=============================================================================
73 //=============================================================================
74 void HOMARD_Boundary_i::SetName( const char* Name )
76 ASSERT( myHomardBoundary );
77 myHomardBoundary->SetName( Name );
79 //=============================================================================
80 char* HOMARD_Boundary_i::GetName()
82 ASSERT( myHomardBoundary );
83 return CORBA::string_dup( myHomardBoundary->GetName().c_str() );
85 //=============================================================================
86 CORBA::Long HOMARD_Boundary_i::Delete()
88 ASSERT( myHomardBoundary );
89 char* BoundaryName = GetName() ;
90 MESSAGE ( "Delete : destruction de la frontiere " << BoundaryName );
91 return _gen_i->DeleteBoundary(BoundaryName) ;
93 //=============================================================================
94 char* HOMARD_Boundary_i::GetDumpPython()
96 ASSERT( myHomardBoundary );
97 return CORBA::string_dup( myHomardBoundary->GetDumpPython().c_str() );
99 //=============================================================================
100 std::string HOMARD_Boundary_i::Dump() const
102 return HOMARD::Dump( *myHomardBoundary );
105 //=============================================================================
106 bool HOMARD_Boundary_i::Restore( const std::string& stream )
108 return HOMARD::Restore( *myHomardBoundary, stream );
110 //=============================================================================
111 //=============================================================================
113 //=============================================================================
114 //=============================================================================
115 void HOMARD_Boundary_i::SetType( CORBA::Long Type )
117 ASSERT( myHomardBoundary );
118 myHomardBoundary->SetType( Type );
120 //=============================================================================
121 CORBA::Long HOMARD_Boundary_i::GetType()
123 ASSERT( myHomardBoundary );
124 return CORBA::Long( myHomardBoundary->GetType() );
126 //=============================================================================
127 void HOMARD_Boundary_i::SetMeshName( const char* MeshName )
129 ASSERT( myHomardBoundary );
130 myHomardBoundary->SetMeshName( MeshName );
132 //=============================================================================
133 char* HOMARD_Boundary_i::GetMeshName()
135 ASSERT( myHomardBoundary );
136 return CORBA::string_dup( myHomardBoundary->GetMeshName().c_str() );
138 //=============================================================================
139 void HOMARD_Boundary_i::SetMeshFile( const char* MeshFile )
141 ASSERT( myHomardBoundary );
142 myHomardBoundary->SetMeshFile( MeshFile );
143 _gen_i->PublishResultInSmesh(MeshFile, 0);
145 //=============================================================================
146 char* HOMARD_Boundary_i::GetMeshFile()
148 ASSERT( myHomardBoundary );
149 return CORBA::string_dup( myHomardBoundary->GetMeshFile().c_str() );
151 //=============================================================================
152 void HOMARD_Boundary_i::SetCylinder( double X0, double X1, double X2, double X3, double X4, double X5, double X6 )
154 ASSERT( myHomardBoundary );
155 myHomardBoundary->SetCylinder( X0, X1, X2, X3, X4, X5, X6 );
157 //=============================================================================
158 void HOMARD_Boundary_i::SetSphere( double Xcentre, double Ycentre, double ZCentre, double rayon )
160 ASSERT( myHomardBoundary );
161 myHomardBoundary->SetSphere( Xcentre, Ycentre, ZCentre, rayon );
163 //=============================================================================
164 HOMARD::double_array* HOMARD_Boundary_i::GetCoords()
166 ASSERT( myHomardBoundary );
167 HOMARD::double_array_var aResult = new HOMARD::double_array();
168 std::vector<double> mesCoor = myHomardBoundary->GetCoords();
169 aResult->length( mesCoor .size() );
170 std::vector<double>::const_iterator it;
172 for ( it = mesCoor.begin(); it != mesCoor.end(); it++ )
173 aResult[i++] = (*it);
174 return aResult._retn();
176 //=============================================================================
177 void HOMARD_Boundary_i::SetLimit( double Xincr, double Yincr, double Zincr )
179 ASSERT( myHomardBoundary );
180 myHomardBoundary->SetLimit( Xincr, Yincr, Zincr );
182 //=============================================================================
183 HOMARD::double_array* HOMARD_Boundary_i::GetLimit()
185 ASSERT( myHomardBoundary );
186 HOMARD::double_array_var aResult = new HOMARD::double_array();
187 std::vector<double> mesCoor = myHomardBoundary->GetLimit();
188 aResult->length( mesCoor .size() );
189 std::vector<double>::const_iterator it;
191 for ( it = mesCoor.begin(); it != mesCoor.end(); it++ )
192 aResult[i++] = (*it);
193 return aResult._retn();
195 //=============================================================================
196 void HOMARD_Boundary_i::AddGroup( const char* Group)
198 ASSERT( myHomardBoundary );
199 myHomardBoundary->AddGroup( Group );
201 //=============================================================================
202 void HOMARD_Boundary_i::SetGroups(const HOMARD::ListGroupType& ListGroup)
204 ASSERT( myHomardBoundary );
205 std::list<std::string> ListString;
206 for ( int i = 0; i < ListGroup.length(); i++ )
208 ListString.push_back(std::string(ListGroup[i]));
210 myHomardBoundary->SetGroups( ListString );
212 //=============================================================================
213 HOMARD::ListGroupType* HOMARD_Boundary_i::GetGroups()
215 ASSERT( myHomardBoundary );
216 const std::list<std::string>& ListString = myHomardBoundary->GetGroups();
217 HOMARD::ListGroupType_var aResult = new HOMARD::ListGroupType;
218 aResult->length( ListString.size() );
219 std::list<std::string>::const_iterator it;
221 for ( it = ListString.begin(); it != ListString.end(); it++ )
223 aResult[i++] = CORBA::string_dup( (*it).c_str() );
225 return aResult._retn();
227 //=============================================================================
228 //=============================================================================
229 // Liens avec les autres structures
230 //=============================================================================
231 //=============================================================================
232 void HOMARD_Boundary_i::SetCaseCreation( const char* NomCaseCreation )
234 ASSERT( myHomardBoundary );
235 myHomardBoundary->SetCaseCreation( NomCaseCreation );
237 //=============================================================================
238 char* HOMARD_Boundary_i::GetCaseCreation()
240 ASSERT( myHomardBoundary );
241 return CORBA::string_dup( myHomardBoundary->GetCaseCreation().c_str() );