1 // Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
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.
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.
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
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 // SMESH SMESH_I : idl implementation based on 'SMESH' unit's classes
23 // File : SMESH_Group_i.hxx
24 // Author : Sergey ANIKIN, OCC
27 #ifndef SMESH_Group_i_HeaderFile
28 #define SMESH_Group_i_HeaderFile
31 #include "SMESH_Mesh_i.hxx"
33 #include <SALOMEconfig.h>
34 #include CORBA_SERVER_HEADER(SMESH_Group)
35 #include CORBA_SERVER_HEADER(SMESH_Mesh)
36 #include CORBA_CLIENT_HEADER(GEOM_Gen)
38 #include "SALOME_GenericObj_i.hh"
41 class SMESHDS_GroupBase;
46 class SMESH_I_EXPORT SMESH_GroupBase_i:
47 public virtual POA_SMESH::SMESH_GroupBase,
48 public virtual SALOME::GenericObj_i
51 SMESH_GroupBase_i(PortableServer::POA_ptr thePOA,
52 SMESH_Mesh_i* theMeshServant,
53 const int theLocalID );
54 virtual ~SMESH_GroupBase_i();
56 // CORBA interface implementation
57 void SetName(const char* name);
59 SMESH::ElementType GetType();
61 CORBA::Boolean IsEmpty();
62 CORBA::Boolean Contains(CORBA::Long elem_id);
63 CORBA::Long GetID(CORBA::Long elem_index);
64 SMESH::long_array* GetListOfID();
65 SMESH::SMESH_Mesh_ptr GetMesh();
68 * Returns statistic of mesh elements
69 * Result array of number enityties
70 * Inherited from SMESH_IDSource
72 virtual SMESH::long_array* GetMeshInfo();
74 // Inherited from SMESH_IDSource interface
75 virtual SMESH::long_array* GetIDs();
77 // Internal C++ interface
78 int GetLocalID() const { return myLocalID; }
79 SMESH_Mesh_i* GetMeshServant() const { return myMeshServant; }
80 SMESH_Group* GetSmeshGroup() const;
81 SMESHDS_GroupBase* GetGroupDS() const;
83 void SetColor(const SALOMEDS::Color& color);
84 SALOMEDS::Color GetColor();
86 void SetColorNumber(CORBA::Long color);
87 CORBA::Long GetColorNumber();
90 SMESH_Mesh_i* myMeshServant;
93 void changeLocalId(int localId) { myLocalID = localId; }
94 friend void SMESH_Mesh_i::CheckGeomGroupModif();
101 class SMESH_I_EXPORT SMESH_Group_i:
102 public virtual POA_SMESH::SMESH_Group,
103 public SMESH_GroupBase_i
106 SMESH_Group_i( PortableServer::POA_ptr thePOA, SMESH_Mesh_i* theMeshServant, const int theLocalID );
108 // CORBA interface implementation
110 CORBA::Long Add( const SMESH::long_array& theIDs );
111 CORBA::Long Remove( const SMESH::long_array& theIDs );
113 CORBA::Long AddByPredicate( SMESH::Predicate_ptr thePredicate );
114 CORBA::Long RemoveByPredicate( SMESH::Predicate_ptr thePredicate );
117 // =========================
118 // Group linked to geometry
119 // =========================
121 class SMESH_I_EXPORT SMESH_GroupOnGeom_i:
122 public virtual POA_SMESH::SMESH_GroupOnGeom,
123 public SMESH_GroupBase_i
126 SMESH_GroupOnGeom_i( PortableServer::POA_ptr thePOA, SMESH_Mesh_i* theMeshServant, const int theLocalID );
128 // CORBA interface implementation
129 GEOM::GEOM_Object_ptr GetShape();