1 // Copyright (C) 2007-2013 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
26 #include "GMESHClient.hxx"
27 #include "MESHClient.hxx"
28 #include "SUPPORTClient.hxx"
29 #include "FIELDClient.hxx"
30 #include CORBA_CLIENT_HEADER(MED)
32 using namespace MEDMEM;
33 using namespace MED_EN;
37 if ((SWIG_ConvertPtr($input, (void **) &$1, $1_descriptor, 0)) == -1) {
39 if ((SWIG_ConvertPtr($input, (void **) &client, $descriptor(MESHClient *), 0)) == -1) {
40 SWIG_Python_TypeError("MESH* or MESHClient*", $input);
47 %include "libMedCorba_Swig.i"
48 %include "libMEDMEM_Swig.i"
50 %typecheck(SWIG_TYPECHECK_POINTER) SALOME_MED::FIELDDOUBLE_ptr, SALOME_MED::FIELDINT_ptr
56 managing C++ exception in the Python API
60 class PyAllowThreadsGuard {
62 PyAllowThreadsGuard() { _save = PyEval_SaveThread(); }
63 ~PyAllowThreadsGuard() { PyEval_RestoreThread(_save); }
68 PyAllowThreadsGuard guard;
73 class GMESHClient : public GMESH {
77 GMESHClient(const SALOME_MED::GMESH_ptr m);
83 self->removeReference();
88 class MESHClient : public MESH {
92 MESHClient(const SALOME_MED::MESH_ptr m);
98 self->removeReference();
103 MESH * getMeshPointer(MESHClient * input);
105 MESH * getMeshPointer(MESHClient * input)
107 return (MESH *) input;
111 class SUPPORTClient : public SUPPORT {
115 SUPPORTClient(const SALOME_MED::SUPPORT_ptr S,
122 self->removeReference();
128 template<class T, class INTERLACING_TAG>
129 class FIELDClient : public FIELD<T,INTERLACING_TAG>
133 FIELDClient(U ptrCorba,MEDMEM::SUPPORT * S = NULL);
137 %template (FIELDDOUBLEClient) FIELDClient<double, FullInterlace>;
138 %template (FIELDDOUBLENOINTERLACEClient) FIELDClient<double, NoInterlace>;
139 %template (FIELDDOUBLENOINTERLACEBYTYPEClient) FIELDClient<double, NoInterlaceByType>;
140 %template (FIELDINTClient) FIELDClient<int, FullInterlace>;
141 %template (FIELDINTNOINTERLACEClient) FIELDClient<int, NoInterlace>;
142 %template (FIELDINTNOINTERLACEBYTYPEClient) FIELDClient<int, NoInterlaceByType>;
144 %extend FIELDClient<double, FullInterlace>
146 %template(FIELDDOUBLEClient) FIELDClient<SALOME_MED::FIELDDOUBLE_ptr>;
149 %extend FIELDClient<double, NoInterlace>
151 %template(FIELDDOUBLENOINTERLACEClient) FIELDClient<SALOME_MED::FIELDDOUBLE_ptr>;
154 %extend FIELDClient<double, NoInterlaceByType>
156 %template(FIELDDOUBLENOINTERLACEBYTYPEClient) FIELDClient<SALOME_MED::FIELDDOUBLE_ptr>;
159 %extend FIELDClient<int, FullInterlace>
161 %template(FIELDINTClient) FIELDClient<SALOME_MED::FIELDINT_ptr>;
164 %extend FIELDClient<int, NoInterlace>
166 %template(FIELDINTNOINTERLACEClient) FIELDClient<SALOME_MED::FIELDINT_ptr>;
169 %extend FIELDClient<int, NoInterlaceByType>
171 %template(FIELDINTNOINTERLACEBYTYPEClient) FIELDClient<SALOME_MED::FIELDINT_ptr>;
174 FIELD<double> * getDoublePointer(FIELDClient<double,FullInterlace> * input);
176 FIELD<double,NoInterlace> *getDoubleNoInterlacePointer(FIELDClient<double,NoInterlace> * input);
178 FIELD<double,NoInterlaceByType> *getDoubleNoInterlaceByTypePointer(FIELDClient<double,NoInterlaceByType> * input);
180 FIELD<int> * getIntPointer(FIELDClient<int,FullInterlace> * input);
182 FIELD<int,NoInterlace> * getIntNoInterlacePointer(FIELDClient<int,NoInterlace> * input);
184 FIELD<int,NoInterlaceByType> * getIntNoInterlaceByTypePointer(FIELDClient<int,NoInterlaceByType> * input);
187 FIELD<double> * getDoublePointer(FIELDClient<double,FullInterlace> * input)
189 return (FIELD<double> *) input;
192 FIELD<double,NoInterlace> *getDoubleNoInterlacePointer(FIELDClient<double,NoInterlace> * input)
194 return (FIELD<double,NoInterlace> *) input;
197 FIELD<double,NoInterlaceByType> *getDoubleNoInterlaceByTypePointer(FIELDClient<double,NoInterlaceByType> * input)
199 return (FIELD<double,NoInterlaceByType> *) input;
202 FIELD<int> * getIntPointer(FIELDClient<int,FullInterlace> * input)
204 return (FIELD<int> *) input;
207 FIELD<int,NoInterlace> * getIntNoInterlacePointer(FIELDClient<int,NoInterlace> * input)
209 return (FIELD<int,NoInterlace> *) input;
212 FIELD<int,NoInterlaceByType> * getIntNoInterlaceByTypePointer(FIELDClient<int,NoInterlaceByType> * input)
214 return (FIELD<int,NoInterlaceByType> *) input;