X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSMESH_SWIG%2Fsmesh.py;h=a764de5b9d873075dc63ef67284909824efa8639;hb=3fefd303ac5efcb36f07b6803d8a8600a5c8d2ca;hp=c13a57e8e4c414f784445f560a6898df85bbc23f;hpb=bd4e115a78b52e3fbc016e5e30bb0e19b2a9e7d6;p=modules%2Fsmesh.git diff --git a/src/SMESH_SWIG/smesh.py b/src/SMESH_SWIG/smesh.py index c13a57e8e..a764de5b9 100644 --- a/src/SMESH_SWIG/smesh.py +++ b/src/SMESH_SWIG/smesh.py @@ -1,5 +1,5 @@ # -*- coding: iso-8859-1 -*- -# Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE +# Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE # # Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, # CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS @@ -33,37 +33,85 @@ import salome from salome import * import geompy -import smeshDC -from smeshDC import * - -# get instance of class smeshDC -smesh = salome.lcc.FindOrLoadComponent("FactoryServer", "SMESH") -smesh.init_smesh(salome.myStudy,geompy.geom) - -# load plugins -from smeshDC import Mesh, algoCreator -for pluginName in os.environ["SMESH_MeshersList"].split(":"): - - pluginName += "DC" - try: - exec("from %s import *" % pluginName ) - except Exception, e: - print "Exception while loading %s: %s" % ( pluginName, e ) - continue - exec("import %s" % pluginName ) - plugin = eval(pluginName) - - # add methods creating algorithms to Mesh - for k in dir(plugin): - if k[0] == '_':continue - algo = getattr(plugin,k) - if type( algo ).__name__ == 'classobj' and hasattr( algo, "meshMethod"): - if not hasattr( Mesh, algo.meshMethod ): - setattr( Mesh, algo.meshMethod, algoCreator()) - getattr( Mesh, algo.meshMethod ).add( algo ) - -# Export the methods of smeshDC -for k in dir(smesh): - if k[0] == '_':continue - globals()[k]=getattr(smesh,k) -del k + +import SMESH, SALOMEDS +from salome.smesh import smeshBuilder + +# retrieve SMESH engine in try/except block +# to avoid problems in some cases, e.g. when generating documentation +try: + # get instance of class smeshBuilder + engineSmesh = salome.lcc.FindOrLoadComponent( "FactoryServer", "SMESH" ) + smesh = smeshBuilder.New(salome.myStudy, engineSmesh) +except: + print "exception in smesh.py: instance creation failed" + smesh = None + pass + +# load plugins and add dynamically generated methods to Mesh class, +# the same for for global variables declared by plug-ins +from salome.smesh.smeshBuilder import * +from salome.smesh.smeshBuilder import Mesh, algoCreator +for pluginName in os.environ[ "SMESH_MeshersList" ].split( ":" ): + # + #print "pluginName: ", pluginName + pluginBuilderName = pluginName + "Builder" + try: + exec( "from salome.%s.%s import *" % (pluginName, pluginBuilderName)) + except Exception, e: + print "Exception while loading %s: %s" % ( pluginBuilderName, e ) + continue + exec( "from salome.%s import %s" % (pluginName, pluginBuilderName)) + plugin = eval( pluginBuilderName ) + + # add methods creating algorithms to Mesh + for k in dir( plugin ): + if k[0] == '_': continue + algo = getattr( plugin, k ) + if type( algo ).__name__ == 'classobj' and hasattr( algo, "meshMethod" ): + if not hasattr( Mesh, algo.meshMethod ): + setattr( Mesh, algo.meshMethod, algoCreator() ) + pass + getattr( Mesh, algo.meshMethod ).add( algo ) + pass + pass + pass +del pluginName + +# export the methods of smeshBuilder +if smesh: + for k in dir( smesh ): + if k[0] == '_': continue + globals()[k] = getattr( smesh, k ) + del k + pass + +print """ +=============================================================================== +WARNING: +Usage of smesh.py is deprecated in SALOME V7.2! +smesh.py will be removed in a future version! +TODO: +The following changes in your scripts are required to avoid this message: + +replace +------- + +import smesh, SMESH +smesh.SetCurrentStudy(theStudy) + +with +---- + +import SMESH +from salome.smesh import smeshBuilder +smesh = smeshBuilder.New(salome.myStudy) + +you also need to modify some lines where smeshBuilder is used instead of smesh + +algo=smesh.xxxx ==> algo=smeshBuilder.xxxx + +See also SMESH User's Guide for more details + +=============================================================================== +"""