3 # Copyright (C) 2005 OPEN CASCADE, CEA, EDF R&D, LEG
4 # PRINCIPIA R&D, EADS CCR, Lip6, BV, CEDRAT
5 # This library is free software; you can redistribute it and/or
6 # modify it under the terms of the GNU Lesser General Public
7 # License as published by the Free Software Foundation; either
8 # version 2.1 of the License.
10 # This library is distributed in the hope that it will be useful
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 # Lesser General Public License for more details.
15 # You should have received a copy of the GNU Lesser General Public
16 # License along with this library; if not, write to the Free Software
17 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 import sys, os, string, glob, time, pickle
24 from launchConfigureParser import verbose
28 # salome_subdir variable is used for composing paths like $KERNEL_ROOT_DIR/share/salome/resources/kernel, etc.
29 # before moving to SUIT-based gui, instead of salome_subdir there was args['appname'] used.
30 # but after - 'appname' = "SalomeApp", so using it in making the subdirectory is an error.
31 salome_subdir = "salome"
33 # -----------------------------------------------------------------------------
35 def add_path(directory, variable_name):
36 """Function helper to add environment variables"""
37 if not os.environ.has_key(variable_name):
38 os.environ[variable_name] = ""
40 if os.path.exists(directory):
42 for _dir in os.environ[variable_name].split(":"):
43 if os.path.exists(_dir):
44 if not os.path.samefile(_dir, directory):
47 if os.path.abspath(_dir) != os.path.abspath(directory):
51 newpath[:0] = [ directory ]
52 newpath = string.join(newpath,":")
53 os.environ[variable_name] = newpath
54 if variable_name == "PYTHONPATH":
55 sys.path[:0] = [directory]
57 # -----------------------------------------------------------------------------
62 if __lib__dir__: return __lib__dir__
64 if platform.architecture()[0] == "64bit":
65 __lib__dir__ = "lib64"
70 # -----------------------------------------------------------------------------
74 Get list of modules, paths.
76 Read args from launch configure xml file and command line options.
77 Check variables <module>_ROOT_DIR and set list of used modules.
78 Return args, modules_list, modules_root_dir
81 # read args from launch configure xml file and command line options
83 import launchConfigureParser
84 args = launchConfigureParser.get_env()
86 # Check variables <module>_ROOT_DIR
87 # and set list of used modules (without KERNEL)
90 if args.has_key("modules"):
91 modules_list += args["modules"]
92 # KERNEL must be last in the list to locate it at the first place in PATH
94 modules_list[:0] = ["GUI"]
95 modules_list[:0] = ["KERNEL"]
96 modules_list.reverse()
101 for module in modules_list :
102 module_variable=module+"_ROOT_DIR"
103 if not os.environ.has_key(module_variable):
104 print "*******************************************************"
106 print "* Environment variable",module_variable,"must be set"
107 print "* Module", module, "will be not available"
109 print "********************************************************"
110 to_remove_list.append(module)
113 module_root_dir = os.environ[module_variable]
114 modules_root_dir[module]=module_root_dir
116 for to_remove in to_remove_list:
117 modules_list.remove(to_remove)
119 while "KERNEL" in modules_list:
120 modules_list.remove("KERNEL")
123 while "GUI" in modules_list:
124 modules_list.remove("GUI")
127 if "SUPERV" in modules_list and not 'superv' in args['standalone']:
128 args['standalone'].append("superv")
131 return args, modules_list, modules_root_dir
133 # -----------------------------------------------------------------------------
135 def set_env(args, modules_list, modules_root_dir):
136 """Add to the PATH-variables modules specific paths"""
138 python_version="python%d.%d" % sys.version_info[0:2]
139 modules_root_dir_list = []
141 modules_list = modules_list[:] + ["GUI"]
142 modules_list = modules_list[:] + ["KERNEL"]
143 for module in modules_list :
144 if modules_root_dir.has_key(module):
145 module_root_dir = modules_root_dir[module]
146 modules_root_dir_list[:0] = [module_root_dir]
147 add_path(os.path.join(module_root_dir,get_lib_dir(),salome_subdir),
149 add_path(os.path.join(module_root_dir,"bin",salome_subdir),
151 if os.path.exists(module_root_dir + "/examples") :
152 add_path(os.path.join(module_root_dir,"examples"),
155 add_path(os.path.join(module_root_dir,"bin",salome_subdir),
157 add_path(os.path.join(module_root_dir,get_lib_dir(),
158 python_version,"site-packages",
161 add_path(os.path.join(module_root_dir,get_lib_dir(),salome_subdir),
163 add_path(os.path.join(module_root_dir,get_lib_dir(),
164 python_version,"site-packages",
172 os.environ["SALOMEPATH"]=":".join(modules_root_dir_list)
174 # set trace environment variable
176 if not os.environ.has_key("SALOME_trace"):
177 os.environ["SALOME_trace"]="local"
179 os.environ["SALOME_trace"]="file:"+args['file'][0]
181 os.environ["SALOME_trace"]="with_logger"
183 # set environment for SMESH plugins
185 if "SMESH" in modules_list:
186 os.environ["SMESH_MeshersList"]="StdMeshers"
187 if not os.environ.has_key("SALOME_StdMeshersResources"):
188 os.environ["SALOME_StdMeshersResources"] \
189 = modules_root_dir["SMESH"]+"/share/"+args["appname"]+"/resources/smesh"
191 if args.has_key("SMESH_plugins"):
192 for plugin in args["SMESH_plugins"]:
194 if os.environ.has_key(plugin+"_ROOT_DIR"):
195 plugin_root = os.environ[plugin+"_ROOT_DIR"]
197 # workaround to avoid modifications of existing environment
198 if os.environ.has_key(plugin.upper()+"_ROOT_DIR"):
199 plugin_root = os.environ[plugin.upper()+"_ROOT_DIR"]
202 if plugin_root != "":
203 os.environ["SMESH_MeshersList"] \
204 = os.environ["SMESH_MeshersList"]+":"+plugin
205 if not os.environ.has_key("SALOME_"+plugin+"Resources"):
206 os.environ["SALOME_"+plugin+"Resources"] \
207 = plugin_root+"/share/"+args["appname"]+"/resources/"+plugin.lower()
208 add_path(os.path.join(plugin_root,get_lib_dir(),python_version,
209 "site-packages",salome_subdir),
211 add_path(os.path.join(plugin_root,get_lib_dir(),salome_subdir),
213 add_path(os.path.join(plugin_root,get_lib_dir(),salome_subdir),
215 add_path(os.path.join(plugin_root,"bin",salome_subdir),
217 add_path(os.path.join(plugin_root,"bin",salome_subdir),
222 # set environment for SUPERV module
223 os.environ["ENABLE_MACRO_NODE"]="1"
224 # set resources variables if not yet set
225 # Done now by launchConfigureParser.py
226 #if os.getenv("GUI_ROOT_DIR"):
227 #if not os.getenv("SalomeAppConfig"): os.environ["SalomeAppConfig"] = os.getenv("GUI_ROOT_DIR") + "/share/salome/resources/gui"
229 # set CSF_PluginDefaults variable only if it is not customized
231 if not os.getenv("CSF_PluginDefaults"):
232 os.environ["CSF_PluginDefaults"] \
233 = os.path.join(modules_root_dir["KERNEL"],"share",
234 salome_subdir,"resources","kernel")
235 os.environ["CSF_SALOMEDS_ResourcesDefaults"] \
236 = os.path.join(modules_root_dir["KERNEL"],"share",
237 salome_subdir,"resources","kernel")
239 if "GEOM" in modules_list:
240 if verbose(): print "GEOM OCAF Resources"
241 os.environ["CSF_GEOMDS_ResourcesDefaults"] \
242 = os.path.join(modules_root_dir["GEOM"],"share",
243 salome_subdir,"resources","geom")
244 if verbose(): print "GEOM Shape Healing Resources"
245 os.environ["CSF_ShHealingDefaults"] \
246 = os.path.join(modules_root_dir["GEOM"],"share",
247 salome_subdir,"resources","geom")
249 # -----------------------------------------------------------------------------
251 from killSalome import killAllPorts
255 kill servers from a previous SALOME exection, if needed,
256 on the CORBA port given in args of runSalome
259 from killSalomeWithPort import killMyPort
260 my_port=str(args['port'])
264 print "problem in killLocalPort()"
268 def givenPortKill(port):
270 kill servers from a previous SALOME exection, if needed,
271 on the same CORBA port
274 from killSalomeWithPort import killMyPort
279 print "problem in LocalPortKill(), killMyPort("<<port<<")"
283 def kill_salome(args):
285 Kill servers from previous SALOME executions, if needed;
286 depending on args 'killall' or 'portkill', kill all executions,
287 or only execution on the same CORBA port
292 elif args['portkill']:
293 givenPortKill(str(args['port']))
295 # -----------------------------------------------------------------------------
297 # Definition des classes d'objets pour le lancement des Server CORBA
301 """Generic class for CORBA server launch"""
307 if self.args['xterm']:
308 self.ARGS=['xterm', '-iconic', '-sb', '-sl', '500', '-hold']
310 def __init__(self,args):
318 if self.args['xterm']:
319 # (Debian) send LD_LIBRARY_PATH to children shells (xterm)
320 env_ld_library_path=['env', 'LD_LIBRARY_PATH='
321 + os.getenv("LD_LIBRARY_PATH")]
322 myargs = myargs +['-T']+self.CMD[:1]+['-e'] + env_ld_library_path
323 command = myargs + self.CMD
324 if verbose(): print "command = ", command
325 pid = os.spawnvp(os.P_NOWAIT, command[0], command)
326 process_id[pid]=self.CMD
330 class InterpServer(Server):
331 def __init__(self,args):
333 env_ld_library_path=['env', 'LD_LIBRARY_PATH=' + os.getenv("LD_LIBRARY_PATH")]
334 self.CMD=['xterm', '-e']+ env_ld_library_path + ['python']
335 #self.CMD=['xterm', '-e', 'python']
340 #print "command = ", command
341 pid = os.spawnvp(os.P_NOWAIT, command[0], command)
342 process_id[pid]=self.CMD
347 class CatalogServer(Server):
348 def __init__(self,args):
351 self.SCMD1=['SALOME_ModuleCatalog_Server','-common']
353 home_dir=os.getenv('HOME')
354 if home_dir is not None:
355 self.SCMD2=['-personal',os.path.join(home_dir,'Salome/resources/CatalogModulePersonnel.xml')]
357 def setpath(self,modules_list,modules_root_dir):
359 list_modules = modules_list[:]
360 list_modules.reverse()
361 if self.args["gui"] :
362 list_modules = ["KERNEL", "GUI"] + list_modules
364 list_modules = ["KERNEL"] + list_modules
365 for module in list_modules:
366 if modules_root_dir.has_key(module):
367 module_root_dir=modules_root_dir[module]
368 module_cata=module+"Catalog.xml"
369 #print " ", module_cata
370 if os.path.exists(os.path.join(module_root_dir,
371 "share",salome_subdir,
372 "resources",module.lower(),
375 glob.glob(os.path.join(module_root_dir,
376 "share",salome_subdir,
377 "resources",module.lower(),
381 glob.glob(os.path.join(module_root_dir,
382 "share",salome_subdir,
387 self.CMD=self.SCMD1 + [string.join(cata_path,':')] + self.SCMD2
391 class SalomeDSServer(Server):
392 def __init__(self,args):
395 self.CMD=['SALOMEDS_Server']
399 class RegistryServer(Server):
400 def __init__(self,args):
403 self.CMD=['SALOME_Registry_Server', '--salome_session','theSession']
407 class ContainerCPPServer(Server):
408 def __init__(self,args):
411 self.CMD=['SALOME_Container','FactoryServer']
415 class ContainerPYServer(Server):
416 def __init__(self,args):
419 self.CMD=['SALOME_ContainerPy.py','FactoryServerPy']
423 class ContainerSUPERVServer(Server):
424 def __init__(self,args):
427 self.CMD=['SALOME_Container','SuperVisionContainer']
431 class LoggerServer(Server):
432 def __init__(self,args):
435 self.CMD=['SALOME_Logger_Server', 'logger.log']
439 class SessionServer(Server):
440 def __init__(self,args):
441 self.args = args.copy()
442 # Bug 11512 (Problems with runSalome --xterm on Mandrake and Debian Sarge)
446 self.SCMD1=['SALOME_Session_Server']
448 if 'registry' in self.args['embedded']:
449 self.SCMD1+=['--with','Registry',
450 '(','--salome_session','theSession',')']
451 if 'moduleCatalog' in self.args['embedded']:
452 self.SCMD1+=['--with','ModuleCatalog','(','-common']
453 home_dir=os.getenv('HOME')
454 if home_dir is not None:
455 self.SCMD2+=['-personal',os.path.join(home_dir,'Salome/resources/CatalogModulePersonnel.xml')]
457 if 'study' in self.args['embedded']:
458 self.SCMD2+=['--with','SALOMEDS','(',')']
459 if 'cppContainer' in self.args['embedded']:
460 self.SCMD2+=['--with','Container','(','FactoryServer',')']
461 if 'SalomeAppEngine' in self.args['embedded']:
462 self.SCMD2+=['--with','SalomeAppEngine','(',')']
464 if 'cppContainer' in self.args['standalone'] or 'cppContainer' in self.args['embedded']:
466 if 'pyContainer' in self.args['standalone'] or 'pyContainer' in self.args['embedded']:
468 if 'supervContainer' in self.args['containers'] or 'supervContainer' in self.args['standalone']:
469 self.SCMD2+=['SUPERV']
472 session_gui = self.args['session_gui']
480 if self.args['splash'] and self.args['gui']:
481 self.SCMD2+=['SPLASH']
482 if self.args['noexcepthandler']:
483 self.SCMD2+=['noexcepthandler']
484 if self.args.has_key('modules'):
485 self.SCMD2+=['--modules (%s)'%":".join(self.args['modules'])]
486 if self.args.has_key('test') and len(args['test']) > 0:
487 self.SCMD2+=['--test=%s'%(",".join(args['test']))]
489 def setpath(self,modules_list,modules_root_dir):
491 list_modules = modules_list[:]
492 list_modules.reverse()
493 if self.args["gui"] :
494 list_modules = ["KERNEL", "GUI"] + list_modules
496 list_modules = ["KERNEL"] + list_modules
497 for module in list_modules:
498 module_root_dir=modules_root_dir[module]
499 module_cata=module+"Catalog.xml"
500 #print " ", module_cata
501 if os.path.exists(os.path.join(module_root_dir,
502 "share",salome_subdir,
503 "resources",module.lower(),
506 glob.glob(os.path.join(module_root_dir,"share",
507 salome_subdir,"resources",
508 module.lower(),module_cata)))
511 glob.glob(os.path.join(module_root_dir,"share",
512 salome_subdir,"resources",
515 if (self.args["gui"]) & ('moduleCatalog' in self.args['embedded']):
516 self.CMD=self.SCMD1 + [string.join(cata_path,':')] + self.SCMD2
518 self.CMD=self.SCMD1 + self.SCMD2
522 class ContainerManagerServer(Server):
523 def __init__(self,args):
526 self.SCMD1=['SALOME_ContainerManagerServer']
529 if 'registry' in self.args['embedded']:
530 self.SCMD1+=['--with','Registry',
531 '(','--salome_session','theSession',')']
532 if 'moduleCatalog' in self.args['embedded']:
533 self.SCMD1+=['--with','ModuleCatalog','(','-common']
534 self.SCMD2+=['-personal',
535 '${HOME}/Salome/resources/CatalogModulePersonnel.xml',')']
536 if 'study' in self.args['embedded']:
537 self.SCMD2+=['--with','SALOMEDS','(',')']
538 if 'cppContainer' in self.args['embedded']:
539 self.SCMD2+=['--with','Container','(','FactoryServer',')']
541 def setpath(self,modules_list,modules_root_dir):
543 list_modules = modules_list[:]
544 list_modules.reverse()
545 if self.args["gui"] :
546 list_modules = ["GUI"] + list_modules
547 for module in ["KERNEL"] + list_modules:
548 if modules_root_dir.has_key(module):
549 module_root_dir=modules_root_dir[module]
550 module_cata=module+"Catalog.xml"
551 #print " ", module_cata
552 if os.path.exists(os.path.join(module_root_dir,
553 "share",salome_subdir,
554 "resources",module.lower(),
557 glob.glob(os.path.join(module_root_dir,"share",
558 self.args['appname'],"resources",
559 module.lower(),module_cata)))
562 glob.glob(os.path.join(module_root_dir,"share",
563 self.args['appname'],"resources",
567 if (self.args["gui"]) & ('moduleCatalog' in self.args['embedded']):
568 self.CMD=self.SCMD1 + [string.join(cata_path,':')] + self.SCMD2
570 self.CMD=self.SCMD1 + self.SCMD2
572 class NotifyServer(Server):
573 def __init__(self,args,modules_root_dir):
576 self.modules_root_dir=modules_root_dir
577 myLogName = os.environ["LOGNAME"]
578 self.CMD=['notifd','-c',
579 self.modules_root_dir["KERNEL"] +'/share/salome/resources/kernel/channel.cfg',
580 '-DFactoryIORFileName=/tmp/'+myLogName+'_rdifact.ior',
581 '-DChannelIORFileName=/tmp/'+myLogName+'_rdichan.ior',
582 '-DReportLogFile=/tmp/'+myLogName+'_notifd.report',
583 '-DDebugLogFile=/tmp/'+myLogName+'_notifd.debug',
587 # -----------------------------------------------------------------------------
590 """Salome Session Graphic User Interface activation"""
594 import SALOME_ModuleCatalog
598 import SALOME_Session_idl
599 session=clt.waitNS("/Kernel/Session",SALOME.Session)
600 session.GetInterface()
602 # -----------------------------------------------------------------------------
604 def startSalome(args, modules_list, modules_root_dir):
605 """Launch all SALOME servers requested by args"""
606 init_time = os.times()
608 if verbose(): print "startSalome ", args
611 # Initialisation ORB et Naming Service
614 clt=orbmodule.client()
616 # (non obligatoire) Lancement Logger Server
617 # et attente de sa disponibilite dans le naming service
621 myServer=LoggerServer(args)
623 clt.waitLogger("Logger")
625 # Notify Server launch
628 if verbose(): print "Notify Server to launch"
630 myServer=NotifyServer(args,modules_root_dir)
633 # Lancement Session Server (to show splash ASAP)
637 mySessionServ = SessionServer(args)
638 mySessionServ.setpath(modules_list,modules_root_dir)
642 # Lancement Registry Server,
643 # attente de la disponibilite du Registry dans le Naming Service
646 if ('registry' not in args['embedded']) | (args["gui"] == 0) :
647 myServer=RegistryServer(args)
649 clt.waitNSPID("/Registry",myServer.PID)
652 # Lancement Catalog Server,
653 # attente de la disponibilite du Catalog Server dans le Naming Service
657 if ('moduleCatalog' not in args['embedded']) | (args["gui"] == 0):
658 cataServer=CatalogServer(args)
659 cataServer.setpath(modules_list,modules_root_dir)
661 import SALOME_ModuleCatalog
662 clt.waitNSPID("/Kernel/ModulCatalog",cataServer.PID,SALOME_ModuleCatalog.ModuleCatalog)
665 # Lancement SalomeDS Server,
666 # attente de la disponibilite du SalomeDS dans le Naming Service
669 #print "ARGS = ",args
670 if ('study' not in args['embedded']) | (args["gui"] == 0):
672 myServer=SalomeDSServer(args)
674 clt.waitNSPID("/myStudyManager",myServer.PID)
677 # Lancement ContainerManagerServer
680 myCmServer = ContainerManagerServer(args)
681 myCmServer.setpath(modules_list,modules_root_dir)
685 from Utils_Identity import getShortHostName
687 if os.getenv("HOSTNAME") == None:
688 if os.getenv("HOST") == None:
689 os.environ["HOSTNAME"]=getShortHostName()
691 os.environ["HOSTNAME"]=os.getenv("HOST")
693 theComputer = getShortHostName()
696 # Lancement Container C++ local,
697 # attente de la disponibilite du Container C++ local dans le Naming Service
700 if ('cppContainer' in args['standalone']) | (args["gui"] == 0):
701 myServer=ContainerCPPServer(args)
703 clt.waitNSPID("/Containers/" + theComputer + "/FactoryServer",myServer.PID)
706 # Lancement Container Python local,
707 # attente de la disponibilite du Container Python local
708 # dans le Naming Service
711 if 'pyContainer' in args['standalone']:
712 myServer=ContainerPYServer(args)
714 clt.waitNSPID("/Containers/" + theComputer + "/FactoryServerPy",myServer.PID)
717 # Lancement Container Supervision local,
718 # attente de la disponibilite du Container Supervision local
719 # dans le Naming Service
722 if 'supervContainer' in args['standalone']:
723 myServer=ContainerSUPERVServer(args)
725 clt.waitNSPID("/Containers/" + theComputer + "/SuperVisionContainer",myServer.PID)
728 # Attente de la disponibilite du Session Server dans le Naming Service
736 import SALOME_ModuleCatalog
740 import SALOME_Session_idl
741 session=clt.waitNSPID("/Kernel/Session",mySessionServ.PID,SALOME.Session)
743 end_time = os.times()
745 print "Start SALOME, elapsed time : %5.1f seconds"% (end_time[4]
748 # ASV start GUI without Loader
750 # session.GetInterface()
753 # additionnal external python interpreters
760 nbaddi = int(args['interp'][0])
763 traceback.print_exc()
764 print "-------------------------------------------------------------"
765 print "-- to get an external python interpreter:runSalome --interp=1"
766 print "-------------------------------------------------------------"
768 print "additional external python interpreters: ", nbaddi
770 for i in range(nbaddi):
772 anInterp=InterpServer(args)
777 # -----------------------------------------------------------------------------
779 def useSalome(args, modules_list, modules_root_dir):
781 Launch all SALOME servers requested by args,
782 save list of process, give info to user,
783 show registered objects in Naming Service.
788 clt = startSalome(args, modules_list, modules_root_dir)
791 traceback.print_exc()
794 print "--- erreur au lancement Salome ---"
798 from killSalomeWithPort import getPiDict
799 filedict = getPiDict(args['port'])
803 fpid=open(filedict, 'r')
804 process_ids=pickle.load(fpid)
809 fpid=open(filedict, 'w')
810 process_ids.append(process_id)
811 pickle.dump(process_ids,fpid)
814 if verbose(): print """
815 Saving of the dictionary of Salome processes in %s
816 To kill SALOME processes from a console (kill all sessions from all ports):
818 To kill SALOME from the present interpreter, if it is not closed :
819 killLocalPort() --> kill this session
820 (use CORBA port from args of runSalome)
821 givenPortKill(port) --> kill a specific session with given CORBA port
822 killAllPorts() --> kill all sessions
824 runSalome, with --killall option, starts with killing
825 the processes resulting from the previous execution.
829 # Impression arborescence Naming Service
835 print " --- registered objects tree in Naming Service ---"
839 # run python scripts, passed via -t option
840 toimport = args['pyscript']
842 while i < len( toimport ) :
843 if toimport[ i ] == 'killall':
848 print 'importing',toimport[ i ]
849 doimport = 'import ' + toimport[ i ]
855 # -----------------------------------------------------------------------------
857 def registerEnv(args, modules_list, modules_root_dir):
859 Register args, modules_list, modules_root_dir in a file
860 for further use, when SALOME is launched embedded in an other application.
862 fileEnv = '/tmp/' + os.getenv('USER') + "_" + str(args['port']) \
863 + '_' + args['appname'].upper() + '_env'
864 fenv=open(fileEnv,'w')
865 pickle.dump((args, modules_list, modules_root_dir),fenv)
867 os.environ["SALOME_LAUNCH_CONFIG"] = fileEnv
869 # -----------------------------------------------------------------------------
871 def searchFreePort(args, save_config=1):
872 print "Searching for a free port for naming service:",
878 status = os.system("netstat -ltn | grep -E :%s > /dev/null 2>&1"%(NSPORT))
880 print "%s - OK"%(NSPORT)
882 from os import getpid
883 tmp_file = '/tmp/hostname_%s'%(getpid())
884 from os import system
885 system('hostname > %s'%(tmp_file))
890 system('rm -f %s'%(tmp_file))
892 home = os.environ['HOME']
893 appli=os.environ.get("APPLI")
894 if appli is not None:
895 home='%s/%s'%(home,appli)
898 os.environ['OMNIORB_CONFIG'] = '%s/.omniORB_%s_%s.cfg'%(home, myhost, NSPORT)
899 initref = "NameService=corbaname::%s:%s"%(myhost, NSPORT)
900 os.environ['NSPORT'] = "%s"%(NSPORT)
901 os.environ['NSHOST'] = "%s"%(myhost)
902 f = open(os.environ['OMNIORB_CONFIG'], "w")
904 if CORBA.ORB_ID == "omniORB4":
905 f.write("InitRef = %s\n"%(initref))
907 f.write("ORBInitRef %s\n"%(initref))
910 args['port'] = os.environ['NSPORT']
913 from os import system
914 system('ln -sf %s %s/.omniORB_last.cfg'%(os.environ['OMNIORB_CONFIG'], home))
921 msg += "Can't find a free port to launch omniNames\n"
922 msg += "Try to kill the running servers and then launch SALOME again.\n"
928 # -----------------------------------------------------------------------------
931 """Salome Launch, when embedded in other application"""
932 fileEnv = os.environ["SALOME_LAUNCH_CONFIG"]
933 fenv=open(fileEnv,'r')
934 args, modules_list, modules_root_dir = pickle.load(fenv)
937 searchFreePort(args, 0)
938 clt = useSalome(args, modules_list, modules_root_dir)
941 # -----------------------------------------------------------------------------
944 """Salome launch as a main application"""
946 if len(sys.argv) == 2:
947 if sys.argv[1] == "-nothing":
950 print "port:%s"%(os.environ['NSPORT'])
957 if len(sys.argv) > 1:
958 if sys.argv[1] == "--nosave-config":
964 args, modules_list, modules_root_dir = get_config()
966 searchFreePort(args, save_config)
967 set_env(args, modules_list, modules_root_dir)
968 clt = useSalome(args, modules_list, modules_root_dir)
971 # -----------------------------------------------------------------------------
973 if __name__ == "__main__":