1 # Copyright (C) 2012-2015 ALNEOS
2 # Copyright (C) 2016-2024 EDF
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License, or (at your option) any later version.
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Lesser General Public License for more details.
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 # See http://www.alneos.com/ or email : contact@alneos.fr
19 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 # @package GMSHPluginBuilder
24 # Python API for the GMSH meshing plug-in module.
26 from salome.smesh.smesh_algorithm import Mesh_Algorithm
28 # import GMSHPlugin module if possible
40 GMSH_3D_Remote = "GMSH_3D_Remote"
42 ## Base of all GMSH algorithms.
44 class GMSH_Algorithm(Mesh_Algorithm):
46 meshMethod = "Tetrahedron"
49 def __init__(self, mesh, geom=0):
50 Mesh_Algorithm.__init__(self)
51 if noGMSHPlugin: print("Warning: GMSHPlugin module unavailable")
52 self.Create(mesh, geom, self.algoType, "libGMSHEngine.so")
55 ## Defines hypothesis having several parameters
58 if self.algoType == GMSH_2D:
59 hypType = "GMSH_Parameters_2D"
60 elif self.algoType == GMSH:
61 hypType = "GMSH_Parameters"
62 elif self.algoType == GMSH_3D:
63 hypType = "GMSH_Parameters_3D"
64 elif self.algoType == GMSH_3D_Remote:
65 hypType = "GMSH_Parameters_3D"
67 if self.params and self.params.GetName() != hypType:
68 self.mesh.RemoveHypothesis( self.params, self.geom )
71 self.params = self.Hypothesis(hypType, [],"libGMSHEngine.so",UseExisting=0)
74 class GMSH_2D_Algorithm(GMSH_Algorithm):
76 meshMethod = "Triangle"
79 ## Private constructor.
80 def __init__(self, mesh, geom=0):
81 GMSH_Algorithm.__init__(self, mesh, geom)
83 class GMSH_3D_Algorithm(GMSH_Algorithm):
85 meshMethod = "Tetrahedron"
88 ## Private constructor.
89 def __init__(self, mesh, geom=0):
90 GMSH_Algorithm.__init__(self, mesh, geom)
93 class GMSH_3D_Remote_Algorithm(GMSH_Algorithm):
94 meshMethod = "Tetrahedron"
95 algoType = GMSH_3D_Remote
97 ## Private constructor.
98 def __init__(self, mesh, geom=0):
99 GMSH_Algorithm.__init__(self, mesh, geom)