Salome HOME
Update copyright information
[modules/smesh.git] / src / SMESH_SWIG / smesh.py
1 #  -*- coding: iso-8859-1 -*-
2 # Copyright (C) 2007-2012  CEA/DEN, EDF R&D, OPEN CASCADE
3 #
4 # Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
5 # CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 #
7 # This library is free software; you can redistribute it and/or
8 # modify it under the terms of the GNU Lesser General Public
9 # License as published by the Free Software Foundation; either
10 # version 2.1 of the License.
11 #
12 # This library is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15 # Lesser General Public License for more details.
16 #
17 # You should have received a copy of the GNU Lesser General Public
18 # License along with this library; if not, write to the Free Software
19 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
20 #
21 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 #
23
24 #  File   : smesh.py
25 #  Author : Francis KLOSS, OCC
26 #  Module : SMESH
27 #
28 """@package smesh
29  \brief Module smesh
30 """
31
32 import salome
33 from salome import *
34
35 import geompy
36 import smeshDC
37 from smeshDC import *
38
39 # get instance of class smeshDC
40 smesh = salome.lcc.FindOrLoadComponent("FactoryServer", "SMESH")
41 smesh.init_smesh(salome.myStudy,geompy.geom)
42
43 # load plugins
44 from smeshDC import Mesh, algoCreator
45 for pluginName in os.environ["SMESH_MeshersList"].split(":"):
46
47   pluginName += "DC"
48   try:
49     exec("from %s import *" % pluginName )
50   except Exception, e:
51     print "Exception while loading %s: %s" % ( pluginName, e )
52     continue
53   exec("import %s" % pluginName )
54   plugin = eval(pluginName)
55
56   # add methods creating algorithms to Mesh
57   for k in dir(plugin):
58     if k[0] == '_':continue
59     algo = getattr(plugin,k)
60     if type( algo ).__name__ == 'classobj' and hasattr( algo, "meshMethod"):
61       if not hasattr( Mesh, algo.meshMethod ):
62         setattr( Mesh, algo.meshMethod, algoCreator())
63       getattr( Mesh, algo.meshMethod ).add( algo )
64
65 # Export the methods of smeshDC
66 for k in dir(smesh):
67   if k[0] == '_':continue
68   globals()[k]=getattr(smesh,k)
69 del k