1 import os, glob, string, sys
4 # -----------------------------------------------------------------------------
6 ### xml reader for launch configuration file usage
9 def __init__(self, fileName):
12 parser = xml.sax.make_parser()
13 parser.setContentHandler(self)
14 parser.parse(fileName)
17 def CorrectBoolean(self, str):
18 if str in ("yes", "y", "1"):
20 elif str in ("no", "n", "0"):
26 def startElement(self, name, attrs):
27 #print "startElement name=",name
28 #print "startElement attrs=",attrs.getNames()
29 self.space.append(name)
32 if self.space[:2] == ["Configuration-list","launchoptions"] and len(self.space) == 3:
34 elif self.space == ["Configuration-list","modules-list"]:
35 self.opts["modules"] = []
36 elif self.space == ["Configuration-list","modules-list","module"] and "name" in attrs.getNames():
37 for field in attrs.getNames():
39 self.currentModuleName = str(attrs.getValue("name"))
40 self.opts["modules"].append(self.currentModuleName)
42 self.opts[str(attrs.getValue("name"))+"_"+str(field)] = self.CorrectBoolean(attrs.getValue(field))
45 elif self.space == ["Configuration-list","modules-list","module","plugin"] and "name" in attrs.getNames():
46 key = str(self.currentModuleName)+"_plugins"
47 if not self.opts.has_key("key"):
50 self.opts[key].append(attrs.getValue("name"))
51 elif self.space == ["Configuration-list","embedded-list"]:
52 self.opts["embedded"] = []
54 elif self.space == ["Configuration-list","standalone-list"]:
55 self.opts["standalone"] = []
57 elif self.space == ["Configuration-list","containers-list"]:
58 self.opts["containers"] = []
62 def endElement(self, name):
67 def characters(self, content):
68 #print "Characters content:",content
70 self.opts[self.current] = self.CorrectBoolean(content)
71 elif self.space == ["Configuration-list","embedded-list", "embeddedserver"]:
72 self.opts["embedded"].append(content)
73 elif self.space == ["Configuration-list","standalone-list", "standaloneserver"]:
74 self.opts["standalone"].append(content)
75 elif self.space == ["Configuration-list","containers-list", "containertype"]:
76 self.opts["containers"].append(content)
79 def processingInstruction(self, target, data):
82 def setDocumentLocator(self, locator):
85 def startDocument(self):
89 def endDocument(self):
93 # -----------------------------------------------------------------------------
95 ### searching for launch configuration file : $HOME/.$(application_name)/$(application_name).launch
99 for bindir in glob.glob(os.environ["KERNEL_ROOT_DIR"]+"/bin/*"):
100 appname = string.split(bindir, "/").pop()
101 print 'Application name: "'+appname+'"'
102 filename = os.environ["HOME"]+"/."+appname+"/"+appname+".launch"
103 if not os.path.exists(filename) and \
104 not os.path.exists(os.environ["KERNEL_ROOT_DIR"]+"/bin/"+appname+"/"+appname+".launch"):
110 print "Can not find application name"
111 if not os.have_key("KERNEL_ROOT_DIR"):
112 print "KERNEL_ROOT_DIR environment variable must be set"
115 elif not filename or not os.path.exists(filename):
116 filename = os.environ["HOME"]+"/."+appname+"/"+appname+".launch"
117 print "Launch configuration file does not exist. Create default:",filename
118 os.system("mkdir -p "+os.environ["HOME"]+"/."+appname)
119 os.system("cp -f "+os.environ["KERNEL_ROOT_DIR"]+"/bin/"+appname+"/"+appname+".launch "+filename)
122 ### get options from launch configuration file
125 p = xml_parser(filename)
127 print 'Can not read launch configuration file ', filename
137 # --- args completion
138 for aKey in ("containers","embedded","key","modules","standalone"):
139 if not args.has_key(aKey):
141 for aKey in ("gui","logger","xterm","portkill","killall"):
142 if not args.has_key(aKey):
144 args["appname"] = appname
146 ### searching for my port
150 file = open(os.environ["OMNIORB_CONFIG"], "r")
153 l = string.split(s, ":")
154 if string.split(l[0], " ")[0] == "ORBInitRef":
155 my_port = int(l[len(l)-1])
162 args["port"] = my_port
164 # -----------------------------------------------------------------------------
166 ### command line options reader
168 def options_parser(line):
171 for delimiter in [" ", ",", "="]:
173 list += string.split(o, delimiter)
179 print "source=",source
183 while i < len(source):
184 if source[i][0] != '-':
186 elif source[i][1] == '-':
196 while i < len(source) and source[i][0] != '-':
197 result[key].append(source[i])
203 # -----------------------------------------------------------------------------
205 ### read command-line options : each arg given in command line supersedes arg from xml config file
208 opts = options_parser(sys.argv[1:])
210 kernel_root_dir=os.environ["KERNEL_ROOT_DIR"]
215 ### check all options are right
219 if not opt in ("h","g","l","x","m","e","s","c","p","k","t"):
220 print "command line error: -", opt
226 if opts.has_key("h"):
227 print """USAGE: runSalome.py [options]
228 [command line options] :
229 --help or -h : print this help
230 --gui or -g : lancement du GUI
231 --terminal -t : launching without gui (to deny --gui)
232 --logger or -l : redirection des messages dans un fichier
233 --xterm or -x : les serveurs ouvrent une fenêtre xterm et les messages sont affichés dans cette fenêtre
234 --modules=module1,module2,... : où modulen est le nom d'un module Salome à charger dans le catalogue
235 or -m=module1,module2,...
236 --embedded=registry,study,moduleCatalog,cppContainer
237 or -e=registry,study,moduleCatalog,cppContainer
238 : serveurs CORBA embarqués (par defaut: registry,study,moduleCatalog,cppContainer)
239 : (logger,pyContainer,supervContainer ne peuvent pas être embarqués
240 --standalone=registry,study,moduleCatalog,cppContainer,pyContainer,supervContainer
241 or -s=registry,study,moduleCatalog,cppContainer,pyContainer,supervContainer
242 : executables serveurs CORBA indépendants (par défaut: pyContainer,supervContainer)
243 --containers=cpp,python,superv: (obsolete) lancement des containers cpp, python et de supervision
244 or -c=cpp,python,superv : = on prend les defauts de -e et -s
245 --portkill or -p : kill the salome with current port
246 --killall or -k : kill salome
248 La variable d'environnement <modulen>_ROOT_DIR doit etre préalablement
249 positionnée (modulen doit etre en majuscule).
250 KERNEL_ROOT_DIR est obligatoire.
255 ### apply command-line options to the arguments
264 args['modules'] = opts['m']
266 args['embedded'] = opts['e']
268 args['standalone'] = opts['s']
270 args['containers'] = opts['c']
278 # 'terminal' must be processed in the end: to deny any 'gui' options