mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2024-12-29 10:50:34 +05:00
88ff35ddd4
+ minor changes: 1) unify member field names: avoid _my*, replace by either _* or my* 2) BUG: mesh persistent ID is not unique 3) arguments alignement 4) Add SMESHDS_Hypothesis::SaveString() and LoadString() 5) In mesh construction dlg disable "Mesh Type" if it contains ANY only 6) Add SMESH::printErrorInDebugMode argument of SMESH_CATCH 7) Use static_assert to check completeness of arrays corresponding to enum 8) Add renumber arg to ExportUNV() and ExportDAT() 9) Fix some warnings
215 lines
6.7 KiB
C++
215 lines
6.7 KiB
C++
// Copyright (C) 2007-2021 CEA/DEN, EDF R&D, OPEN CASCADE
|
|
//
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
|
//
|
|
// This library is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
// License as published by the Free Software Foundation; either
|
|
// version 2.1 of the License, or (at your option) any later version.
|
|
//
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
// License along with this library; if not, write to the Free Software
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
//
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
|
//
|
|
|
|
// SMESH SMESH_I : idl implementation based on 'SMESH' unit's classes
|
|
// File : SMESH_Group_i.hxx
|
|
// Author : Sergey ANIKIN, OCC
|
|
// Module : SMESH
|
|
//
|
|
#ifndef SMESH_Group_i_HeaderFile
|
|
#define SMESH_Group_i_HeaderFile
|
|
|
|
#include "SMESH.hxx"
|
|
#include "SMESH_Mesh_i.hxx"
|
|
#include "SMESH_Filter_i.hxx"
|
|
|
|
#include <SALOMEconfig.h>
|
|
#include CORBA_SERVER_HEADER(SMESH_Group)
|
|
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
|
#include CORBA_CLIENT_HEADER(GEOM_Gen)
|
|
|
|
#include "SALOME_GenericObj_i.hh"
|
|
|
|
class SMESH_Group;
|
|
class SMESHDS_GroupBase;
|
|
class SMESH_PreMeshInfo;
|
|
|
|
// ===========
|
|
// Group Base
|
|
// ===========
|
|
class SMESH_I_EXPORT SMESH_GroupBase_i:
|
|
public virtual POA_SMESH::SMESH_GroupBase,
|
|
public virtual SALOME::GenericObj_i,
|
|
public SMESH::NotifyerAndWaiter // defined in SMESH_Filter_i.hxx
|
|
{
|
|
public:
|
|
SMESH_GroupBase_i(PortableServer::POA_ptr thePOA,
|
|
SMESH_Mesh_i* theMeshServant,
|
|
const int theLocalID );
|
|
virtual ~SMESH_GroupBase_i();
|
|
|
|
// CORBA interface implementation
|
|
void SetName(const char* name);
|
|
char* GetName();
|
|
SMESH::ElementType GetType();
|
|
SMESH::smIdType Size();
|
|
CORBA::Boolean IsEmpty();
|
|
CORBA::Boolean Contains(SMESH::smIdType elem_id);
|
|
SMESH::smIdType GetID(SMESH::smIdType elem_index);
|
|
SMESH::smIdType_array* GetListOfID();
|
|
SMESH::smIdType_array* GetNodeIDs();
|
|
SMESH::smIdType GetNumberOfNodes();
|
|
CORBA::Boolean IsNodeInfoAvailable(); // for gui
|
|
|
|
virtual SMESH::SMESH_Mesh_ptr GetMesh();
|
|
|
|
/*!
|
|
* Returns number of mesh elements of each \a EntityType
|
|
* Result array of number of elements per \a EntityType
|
|
* Inherited from SMESH_IDSource
|
|
*/
|
|
virtual SMESH::smIdType_array* GetMeshInfo();
|
|
/*!
|
|
* Returns number of mesh elements of each \a ElementType
|
|
*/
|
|
virtual SMESH::smIdType_array* GetNbElementsByType();
|
|
/*!
|
|
* Returns a sequence of all element IDs
|
|
*/
|
|
virtual SMESH::smIdType_array* GetIDs();
|
|
/*!
|
|
* Returns types of elements it contains
|
|
* Inherited from SMESH_IDSource interface
|
|
*/
|
|
virtual SMESH::array_of_ElementType* GetTypes();
|
|
/*!
|
|
* Returns false if GetMeshInfo() returns incorrect information that may
|
|
* happen if mesh data is not yet fully loaded from the file of study.
|
|
*/
|
|
virtual bool IsMeshInfoCorrect();
|
|
/*!
|
|
* Returns mesh unstructed grid information.
|
|
*/
|
|
virtual SALOMEDS::TMPFile* GetVtkUgStream();
|
|
|
|
/*!
|
|
* Returns \c true if \c this group depends on the \a other via
|
|
* FT_BelongToMeshGroup predicate or vice versa
|
|
*/
|
|
virtual CORBA::Boolean IsInDependency( SMESH::SMESH_GroupBase_ptr other );
|
|
|
|
|
|
// Internal C++ interface
|
|
int GetLocalID() const { return myLocalID; } // return group persistent ID
|
|
SMESH_Mesh_i* GetMeshServant() const { return myMeshServant; }
|
|
SMESH_Group* GetSmeshGroup() const;
|
|
SMESHDS_GroupBase* GetGroupDS() const;
|
|
|
|
void SetColor(const SALOMEDS::Color& color);
|
|
SALOMEDS::Color GetColor();
|
|
|
|
void SetColorNumber(CORBA::Long color);
|
|
CORBA::Long GetColorNumber();
|
|
|
|
protected:
|
|
|
|
SMESH_PreMeshInfo* & changePreMeshInfo() { return myPreMeshInfo; }
|
|
SMESH_PreMeshInfo* myPreMeshInfo; // mesh info before full loading from study file
|
|
friend class SMESH_PreMeshInfo;
|
|
|
|
int myNbNodes, myGroupDSTic;
|
|
|
|
private:
|
|
SMESH_Mesh_i* myMeshServant;
|
|
int myLocalID;
|
|
|
|
void changeLocalId(int localId) { myLocalID = localId; }
|
|
friend class SMESH_Mesh_i;
|
|
};
|
|
|
|
// ======
|
|
// Group
|
|
// ======
|
|
|
|
class SMESH_I_EXPORT SMESH_Group_i:
|
|
public virtual POA_SMESH::SMESH_Group,
|
|
public SMESH_GroupBase_i
|
|
{
|
|
public:
|
|
SMESH_Group_i( PortableServer::POA_ptr thePOA,
|
|
SMESH_Mesh_i* theMeshServant,
|
|
const int theLocalID );
|
|
// CORBA interface implementation
|
|
void Clear();
|
|
SMESH::smIdType Add( const SMESH::smIdType_array& theIDs );
|
|
SMESH::smIdType Remove( const SMESH::smIdType_array& theIDs );
|
|
|
|
SMESH::smIdType AddByPredicate( SMESH::Predicate_ptr thePredicate );
|
|
SMESH::smIdType RemoveByPredicate( SMESH::Predicate_ptr thePredicate );
|
|
|
|
SMESH::smIdType AddFrom( SMESH::SMESH_IDSource_ptr theSource );
|
|
};
|
|
|
|
// =========================
|
|
// Group linked to geometry
|
|
// =========================
|
|
|
|
class SMESH_I_EXPORT SMESH_GroupOnGeom_i:
|
|
public virtual POA_SMESH::SMESH_GroupOnGeom,
|
|
public SMESH_GroupBase_i
|
|
{
|
|
public:
|
|
SMESH_GroupOnGeom_i( PortableServer::POA_ptr thePOA,
|
|
SMESH_Mesh_i* theMeshServant,
|
|
const int theLocalID );
|
|
// CORBA interface implementation
|
|
GEOM::GEOM_Object_ptr GetShape();
|
|
};
|
|
|
|
// =========================
|
|
// Group denied by filter
|
|
// =========================
|
|
|
|
class SMESH_I_EXPORT SMESH_GroupOnFilter_i:
|
|
public virtual POA_SMESH::SMESH_GroupOnFilter,
|
|
public SMESH_GroupBase_i
|
|
{
|
|
public:
|
|
SMESH_GroupOnFilter_i( PortableServer::POA_ptr thePOA,
|
|
SMESH_Mesh_i* theMeshServant,
|
|
const int theLocalID );
|
|
~SMESH_GroupOnFilter_i();
|
|
|
|
// Persistence
|
|
static SMESH::Filter_ptr StringToFilter(const std::string& thePersistentString );
|
|
std::string FilterToString() const;
|
|
|
|
static SMESH_PredicatePtr GetPredicate( SMESH::Filter_ptr );
|
|
|
|
// CORBA interface implementation
|
|
void SetFilter(SMESH::Filter_ptr theFilter);
|
|
SMESH::Filter_ptr GetFilter();
|
|
virtual CORBA::Boolean IsUpToDate();
|
|
virtual SMESH::smIdType_array* GetListOfID();
|
|
virtual SMESH::smIdType_array* GetMeshInfo();
|
|
//! @return false in two cases: 1) if mesh not loaded and GetMeshInfo() returns
|
|
//! incorrect information 2) mesh loaded but group contents is not computed.
|
|
virtual bool IsMeshInfoCorrect();
|
|
|
|
// method of SMESH::NotifyerAndWaiter to update self when myFilter changes
|
|
virtual void OnBaseObjModified(NotifyerAndWaiter* filter, bool);
|
|
|
|
private:
|
|
SMESH::Filter_var myFilter;
|
|
};
|
|
#endif
|