1 // Copyright (C) 2011-2020 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, or (at your option) any later version.
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
21 // L'ordre de description des fonctions est le meme dans tous les fichiers
22 // HOMARD_aaaa.idl, HOMARD_aaaa.hxx, HOMARD_aaaa.cxx, HOMARD_aaaa_i.hxx, HOMARD_aaaa_i.cxx :
23 // 1. Les generalites : Name, Delete, DumpPython, Dump, Restore
24 // 2. Les caracteristiques
25 // 3. Le lien avec les autres structures
27 // Quand les 2 fonctions Setxxx et Getxxx sont presentes, Setxxx est decrit en premier
30 #ifndef _HOMARD_CAS_I_HXX_
31 #define _HOMARD_CAS_I_HXX_
33 #include <SALOMEconfig.h>
34 #include CORBA_SERVER_HEADER(ADAPT_Gen)
35 #include CORBA_SERVER_HEADER(HOMARD_Cas)
37 #include "HOMARD_i.hxx"
38 #include "SALOME_Component_i.hxx"
39 #include "SALOME_NamingService.hxx"
40 #include "Utils_CorbaException.hxx"
46 class HOMARDENGINE_EXPORT HOMARD_Cas_i:
47 public virtual Engines_Component_i,
48 public virtual POA_ADAPT::HOMARD_Cas,
49 public virtual PortableServer::ServantBase
52 HOMARD_Cas_i( CORBA::ORB_ptr orb, ADAPT::ADAPT_Gen_var gen_i );
55 virtual ~HOMARD_Cas_i();
58 void SetName( const char* Name );
61 CORBA::Long Delete( CORBA::Long Option );
63 char* GetDumpPython();
65 std::string Dump() const;
66 bool Restore( const std::string& stream );
69 void SetDirName( const char* NomDir );
72 CORBA::Long GetState();
74 CORBA::Long GetNumberofIter();
76 void SetConfType( CORBA::Long ConfType );
77 CORBA::Long GetConfType();
79 void SetExtType( CORBA::Long ExtType );
80 CORBA::Long GetExtType();
82 void SetBoundingBox( const ADAPT::extrema& LesExtremes );
83 ADAPT::extrema* GetBoundingBox();
85 void AddGroup( const char* Group);
86 void SetGroups(const ADAPT::ListGroupType& ListGroup);
87 ADAPT::ListGroupType* GetGroups();
89 void AddBoundary(const char* Boundary);
90 void AddBoundaryGroup(const char* Boundary, const char* Group);
91 ADAPT::ListBoundaryGroupType* GetBoundaryGroup();
92 void SupprBoundaryGroup( );
94 void SetPyram( CORBA::Long Pyram );
95 CORBA::Long GetPyram();
97 void MeshInfo(CORBA::Long Qual, CORBA::Long Diam, CORBA::Long Conn, CORBA::Long Tail, CORBA::Long Inte);
99 // Liens avec les autres structures
100 char* GetIter0Name();
101 ADAPT::HOMARD_Iteration_ptr GetIter0() ;
103 ADAPT::HOMARD_Iteration_ptr NextIteration( const char* Name ) ;
105 ADAPT::HOMARD_Iteration_ptr LastIteration() ;
107 void AddIteration( const char* NomIteration );
110 ADAPT::HOMARD_YACS_ptr CreateYACSSchema( const char* YACSName, const char* ScriptFile, const char* DirName, const char* MeshFile );
113 ::HOMARD_Cas* myHomardCas;
116 ADAPT::ADAPT_Gen_var _gen_i;