1 // Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE
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
20 // SMESH SMESHGUI : GUI for SMESH component
21 // File : libSMESH_Swig.i
22 // Author : Nicolas REJNERI, Open CASCADE S.A.S.
27 #include "libSMESH_Swig.h"
30 /* Exception handler for all functions */
33 class PyAllowThreadsGuard
36 // Py_BEGIN_ALLOW_THREADS
37 PyAllowThreadsGuard() { _save = PyEval_SaveThread(); }
38 // Py_END_ALLOW_THREADS
39 ~PyAllowThreadsGuard() { PyEval_RestoreThread(_save); }
44 PyAllowThreadsGuard guard;
50 %include "std_vector.i"
55 %template(VectorInt) vector<int>;
56 %template() std::pair<int,int>;
57 %template(PairVector) std::vector<std::pair<int,int> >;
61 /* Selection mode enumeration (corresponds to constants from the SALOME_Selection.h) */
82 void Init(int studyID);
84 const char* AddNewMesh(const char* IOR);
85 const char* AddNewHypothesis(const char* IOR);
86 const char* AddNewAlgorithms(const char* IOR);
88 void SetShape(const char* ShapeEntry, const char* MeshEntry);
90 void SetHypothesis(const char* Mesh_Or_SubMesh_Entry, const char* Hypothesis_Entry);
91 void SetAlgorithms(const char* Mesh_Or_SubMesh_Entry, const char* Algorithms_Entry);
93 void UnSetHypothesis(const char* Applied_Hypothesis_Entry );
95 const char* AddSubMesh (const char* Mesh_Entry, const char* SM_IOR, int ST);
96 const char* AddSubMeshOnShape (const char* Mesh_Entry, const char* GeomShape_Entry, const char* SM_IOR, int ST);
98 void SetName(const char* Entry, const char* Name);
100 void SetMeshIcon(const char* Mesh_Entry, const bool isComputed, const bool isEmpty);
102 void CreateAndDisplayActor( const char* Mesh_Entry );
103 void EraseActor( const char* Mesh_Entry, const bool allViewers = false );
104 void UpdateActor( const char* Mesh_Entry );
106 void setSelectionMode( SelectionMode selectionMode);
107 std::vector<int> getSelected( const char* Mesh_Entry );
108 std::vector<std::pair<int,int> > getSelectedEdgeOfCell( const char* Mesh_Entry );
110 // --------------------- for the test purposes -----------------------
111 SelectionMode getSelectionMode();
112 void select( const char *id, std::vector<int> ids, bool append = false );
113 void select( const char *id, int id1, bool append = false );
114 void select( const char *id, std::vector<std::pair<int,int> >, bool apend = false );