1 // SMESH SMESHGUI : GUI for SMESH component
3 // Copyright (C) 2003 CEA
5 // This library is free software; you can redistribute it and/or
6 // modify it under the terms of the GNU Lesser General Public
7 // License as published by the Free Software Foundation; either
8 // version 2.1 of the License.
10 // This library is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 // Lesser General Public License for more details.
15 // You should have received a copy of the GNU Lesser General Public
16 // License along with this library; if not, write to the Free Software
17 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 // See http://www.salome-platform.org or email : webmaster.salome@opencascade.org
23 // File : SMESHGUI_Hypotheses.h
24 // Author : Julia DOROVSKIKH
28 #ifndef SMESHGUI_HypothesesUtils_HeaderFile
29 #define SMESHGUI_HypothesesUtils_HeaderFile
32 #include <qstringlist.h>
34 #include "SALOME_InteractiveObject.hxx"
35 #include "SALOMEDSClient_definitions.hxx"
37 #include "SALOMEconfig.h"
38 #include CORBA_CLIENT_HEADER(SALOMEDS)
39 #include CORBA_SERVER_HEADER(SMESH_Mesh)
40 #include CORBA_SERVER_HEADER(SMESH_Hypothesis)
45 class SMESHGUI_GenericHypothesisCreator;
46 class SALOMEDSClient_SObject;
50 void InitAvailableHypotheses();
52 QStringList GetAvailableHypotheses(const bool isAlgo);
54 HypothesisData* GetHypothesisData(const char* aHypType);
56 SMESHGUI_GenericHypothesisCreator* GetHypothesisCreator(const char* aHypType);
58 SMESH::SMESH_Hypothesis_ptr CreateHypothesis(const char* aHypType,
60 const bool isAlgo = false);
62 bool AddHypothesisOnMesh(SMESH::SMESH_Mesh_ptr aMesh, SMESH::SMESH_Hypothesis_ptr aHyp);
64 bool AddHypothesisOnSubMesh(SMESH::SMESH_subMesh_ptr aSubMesh, SMESH::SMESH_Hypothesis_ptr aHyp);
66 bool RemoveHypothesisOrAlgorithmOnMesh(const Handle(SALOME_InteractiveObject)& IObject);
68 bool RemoveHypothesisOrAlgorithmOnMesh(_PTR(SObject) MorSM,
69 SMESH::SMESH_Hypothesis_ptr anHyp);
71 typedef std::vector<_PTR(SObject)> SObjectList;
72 SObjectList GetMeshesUsingAlgoOrHypothesis(SMESH::SMESH_Hypothesis_ptr AlgoOrHyp ) ;