X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=bin%2Fsmesh_setenv.py;h=a58406c1e78783e067c3b3c0f1ae169dd404de59;hb=29819883c2926e71335ea3036cf05d7f492c7d9c;hp=c0b3f3dc8a84628f4834023765b2e3ce3b93a9b9;hpb=92675bafdfeba644959aaab1964d93e4a27d823f;p=modules%2Fsmesh.git diff --git a/bin/smesh_setenv.py b/bin/smesh_setenv.py index c0b3f3dc8..a58406c1e 100644 --- a/bin/smesh_setenv.py +++ b/bin/smesh_setenv.py @@ -1,6 +1,6 @@ #!/usr/bin/env python # -*- coding: iso-8859-1 -*- -# Copyright (C) 2007-2011 CEA/DEN, EDF R&D, OPEN CASCADE +# Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE # # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public @@ -26,31 +26,45 @@ from setenv import add_path, get_lib_dir, salome_subdir def set_env(args): """Add to the PATH-variables modules specific paths""" - + psep = os.pathsep python_version="python%d.%d" % sys.version_info[0:2] if not os.environ.has_key("SALOME_StdMeshersResources"): os.environ["SALOME_StdMeshersResources"] \ - = os.environ["SMESH_ROOT_DIR"]+"/share/"+salome_subdir+"/resources/smesh" + = os.path.join(os.environ["SMESH_ROOT_DIR"],"share",salome_subdir,"resources","smesh") pass - if args.has_key("SMESH_plugins"): - plugin_list = [] - for plugin in args["SMESH_plugins"]: - plugin_root = "" - if os.environ.has_key(plugin+"_ROOT_DIR"): - plugin_root = os.environ[plugin+"_ROOT_DIR"] - else: - # workaround to avoid modifications of existing environment - if os.environ.has_key(plugin.upper()+"_ROOT_DIR"): - plugin_root = os.environ[plugin.upper()+"_ROOT_DIR"] - pass - pass - if plugin_root != "": + + # find plugins + plugin_list = [] + resource_path_list = [] + for env_var in os.environ.keys(): + value = os.environ[env_var] + if env_var[-9:] == "_ROOT_DIR" and value: + plugin_root = value + plugin = env_var[:-9] # plugin name may have wrong case + + # look for NAMEOFPlugin.xml file among resource files + resource_dir = os.path.join(plugin_root,"share",salome_subdir,"resources",plugin.lower()) + if not os.access( resource_dir, os.F_OK ): continue + for resource_file in os.listdir( resource_dir ): + if not resource_file.endswith( ".xml") or \ + resource_file.lower() != plugin.lower() + ".xml": + continue + # use "resources" attribute of "meshers-group" as name of plugin in a right case + from xml.dom.minidom import parse + xml_doc = parse( os.path.join( resource_dir, resource_file )) + meshers_nodes = xml_doc.getElementsByTagName("meshers-group") + if not meshers_nodes or not meshers_nodes[0].hasAttribute("resources"): continue + plugin = meshers_nodes[0].getAttribute("resources") + if plugin in plugin_list: continue + + # add paths of plugin plugin_list.append(plugin) if not os.environ.has_key("SALOME_"+plugin+"Resources"): - os.environ["SALOME_"+plugin+"Resources"] \ - = plugin_root+"/share/"+salome_subdir+"/resources/"+plugin.lower() + resource_path = os.path.join(plugin_root,"share",salome_subdir,"resources",plugin.lower()) + os.environ["SALOME_"+plugin+"Resources"] = resource_path + resource_path_list.append( resource_path ) add_path(os.path.join(plugin_root,get_lib_dir(),python_version, "site-packages",salome_subdir), "PYTHONPATH") add_path(os.path.join(plugin_root,get_lib_dir(),salome_subdir), "PYTHONPATH") @@ -63,7 +77,8 @@ def set_env(args): add_path(os.path.join(plugin_root,"bin",salome_subdir), "PATH") pass pass - pass - pass - plugin_list.append("StdMeshers") - os.environ["SMESH_MeshersList"] = ":".join(plugin_list) \ No newline at end of file + break + plugin_list.append("StdMeshers") + os.environ["SMESH_MeshersList"] = ":".join(plugin_list) + os.environ["SalomeAppConfig"] = os.environ["SalomeAppConfig"] + psep + psep.join(resource_path_list) +