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 SMESHGUI : GUI for SMESH component
23 // File : SMESHGUI_HypothesesUtils.h
24 // Author : Julia DOROVSKIKH
28 #ifndef SMESHGUI_HypothesesUtils_HeaderFile
29 #define SMESHGUI_HypothesesUtils_HeaderFile
31 #include "SMESH_SMESHGUI.hxx"
34 #include <qstringlist.h>
36 #include "SALOME_InteractiveObject.hxx"
37 #include "SALOMEDSClient_definitions.hxx"
39 #include "SALOMEconfig.h"
40 #include CORBA_CLIENT_HEADER(SALOMEDS)
41 #include CORBA_SERVER_HEADER(SMESH_Mesh)
42 #include CORBA_SERVER_HEADER(SMESH_Hypothesis)
47 #include <boost/shared_ptr.hpp>
51 class SMESHGUI_GenericHypothesisCreator;
52 class SALOMEDSClient_SObject;
53 class algo_error_array;
57 typedef boost::shared_ptr<SMESHGUI_GenericHypothesisCreator> HypothesisCreatorPtr;
60 void InitAvailableHypotheses();
63 QStringList GetAvailableHypotheses( const bool isAlgo,
64 const int theDim = -1,
65 const bool isAux = false,
66 const bool isNeedGeometry = true);
68 QStringList GetHypothesesSets();
71 HypothesesSet* GetHypothesesSet(const QString theSetName);
74 HypothesisData* GetHypothesisData(const char* aHypType);
77 bool IsAvailableHypothesis(const HypothesisData* algoData,
78 const QString& hypType,
82 bool IsCompatibleAlgorithm(const HypothesisData* algo1Data,
83 const HypothesisData* algo2Data);
86 HypothesisCreatorPtr GetHypothesisCreator(const char* aHypType);
89 SMESH::SMESH_Hypothesis_ptr CreateHypothesis(const char* aHypType,
91 const bool isAlgo = false);
94 bool AddHypothesisOnMesh(SMESH::SMESH_Mesh_ptr aMesh, SMESH::SMESH_Hypothesis_ptr aHyp);
97 bool AddHypothesisOnSubMesh(SMESH::SMESH_subMesh_ptr aSubMesh, SMESH::SMESH_Hypothesis_ptr aHyp);
100 bool RemoveHypothesisOrAlgorithmOnMesh(const Handle(SALOME_InteractiveObject)& IObject);
103 bool RemoveHypothesisOrAlgorithmOnMesh(_PTR(SObject) MorSM,
104 SMESH::SMESH_Hypothesis_ptr anHyp);
106 typedef std::vector<_PTR(SObject)> SObjectList;
107 SObjectList GetMeshesUsingAlgoOrHypothesis(SMESH::SMESH_Hypothesis_ptr AlgoOrHyp ) ;
110 QString GetMessageOnAlgoStateErrors(const algo_error_array& errors);