2 # -*- coding: iso-8859-1 -*-
3 # Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
5 # Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
6 # CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
8 # This library is free software; you can redistribute it and/or
9 # modify it under the terms of the GNU Lesser General Public
10 # License as published by the Free Software Foundation; either
11 # version 2.1 of the License.
13 # This library is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 # Lesser General Public License for more details.
18 # You should have received a copy of the GNU Lesser General Public
19 # License along with this library; if not, write to the Free Software
20 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
25 ## \file killSalomeWithPort.py
26 # Stop all %SALOME servers from given sessions by killing them
28 # The sessions are indicated by their ports on the command line as in :
30 # killSalomeWithPort.py 2811 2815
34 import os, sys, pickle, signal, commands,glob
35 from launchConfigureParser import verbose
39 def getPiDict(port,appname='salome',full=True,hidden=True):
41 Get file with list of SALOME processes.
42 This file is located in the user's home directory
43 and named .<user>_<host>_<port>_SALOME_pidict
51 - appname : application name (default is 'SALOME')
52 - full : if True, full path to the file is returned, otherwise only file name is returned
53 - hidden : if True, file name is prefixed with . (dot) symbol; this internal parameter is used
54 to support compatibility with older versions of SALOME
56 from salome_utils import generateFileName, getTmpDir, getHostName
57 hostname = os.getenv("NSHOST") or getHostName()
59 # full path to the pidict file is requested
61 # new-style dot-prefixed pidict files
62 # are in the system-dependant temporary diretory
65 # old-style non-dot-prefixed pidict files
66 # are in the user's home directory
67 dir = os.getenv("HOME")
70 return generateFileName(dir,
74 with_hostname=hostname,
76 with_app=appname.upper())
78 def appliCleanOmniOrbConfig(port):
80 Remove omniorb config files related to the port in SALOME application:
81 - ${HOME}/${APPLI}/USERS/.omniORB_${USER}_${HOSTNAME}_${NSPORT}.cfg
82 - ${HOME}/${APPLI}/USERS/.omniORB_${USER}_last.cfg
83 the last is removed only if the link points to the first file.
85 from salome_utils import generateFileName
86 home = os.getenv("HOME")
87 appli = os.getenv("APPLI")
89 #Run outside application context
92 dir = os.path.join(home, appli,"USERS")
93 omniorb_config = generateFileName(dir, prefix="omniORB",
99 last_running_config = generateFileName(dir, prefix="omniORB",
104 if os.access(last_running_config,os.F_OK):
105 pointedPath = os.readlink(last_running_config)
106 if pointedPath[0] != '/':
107 pointedPath=os.path.join(os.path.dirname(last_running_config), pointedPath)
108 if pointedPath == omniorb_config:
109 os.unlink(last_running_config)
112 if os.access(omniorb_config,os.F_OK):
113 os.remove(omniorb_config)
116 if os.path.lexists(last_running_config):return
118 #try to relink last.cfg to an existing config file if any
119 files = glob.glob(os.path.join(os.environ["HOME"],Utils_Identity.getapplipath(),
120 "USERS",".omniORB_"+salome_utils.getUserName()+"_*.cfg"))
125 if stat.st_atime > current:
126 current=stat.st_atime
129 os.symlink(os.path.normpath(current_config), last_running_config)
134 ########## kills all salome processes with the given port ##########
136 def killMyPort(port):
138 Kill SALOME session running on the specified port.
142 # new-style dot-prefixed pidict file
143 filedict = getPiDict(port, hidden=True)
144 # provide compatibility with old-style pidict file (not dot-prefixed)
145 if not os.path.exists(filedict): filedict = getPiDict(port, hidden=False)
148 fpid = open(filedict, 'r')
150 from salome_utils import generateFileName
151 if sys.platform == "win32":
152 username = os.getenv( "USERNAME" )
154 username = os.getenv('USER')
155 path = os.path.join('/tmp/logs', username)
156 fpidomniNames = generateFileName(path,
158 suffix="Pid_omniNames",
161 if not sys.platform == 'win32':
162 cmd = 'pid=`ps -eo pid,command | egrep "[0-9] omniNames -start %s"` ; echo $pid > %s' % ( str(port), fpidomniNames )
166 fpidomniNamesFile = open(fpidomniNames)
167 lines = fpidomniNamesFile.readlines()
168 fpidomniNamesFile.close()
169 os.remove(fpidomniNames)
172 pidfield = l.split()[0] # pid should be at the first position
173 if sys.platform == "win32":
175 if verbose(): print 'stop process '+pidfield+' : omniNames'
176 win32pm.killpid(int(pidfield),0)
178 if verbose(): print 'stop process '+pidfield+' : omniNames'
179 os.kill(int(pidfield),signal.SIGKILL)
190 process_ids=pickle.load(fpid)
192 for process_id in process_ids:
193 for pid, cmd in process_id.items():
194 if verbose(): print "stop process %s : %s"% (pid, cmd[0])
196 if sys.platform == "win32":
198 win32pm.killpid(int(pid),0)
200 os.kill(int(pid),signal.SIGKILL)
204 if verbose(): print " ------------------ process %s : %s not found"% (pid, cmd[0])
206 pass # for pid, cmd ...
207 pass # for process_id ...
213 cmd='ps -eo pid,command | egrep "[0-9] omniNames -start '+str(port)+'" | sed -e "s%[^0-9]*\([0-9]*\) .*%\\1%g"'
214 pid = commands.getoutput(cmd)
216 while pid and len(a.split()) < 2:
217 a = commands.getoutput("kill -9 " + pid)
218 pid = commands.getoutput(cmd)
223 print "Cannot find or open SALOME PIDs file for port", port
226 appliCleanOmniOrbConfig(port)
229 def killNotifdAndClean(port):
231 Kill notifd daemon and clean application running on the specified port.
236 filedict=getPiDict(port)
237 f=open(filedict, 'r')
240 for pid,process in d.items():
241 if 'notifd' in process:
242 cmd='kill -9 %d'% pid
247 #traceback.print_exc()
250 appliCleanOmniOrbConfig(port)
252 if __name__ == "__main__":
253 for port in sys.argv[1:]: