gajim now create a pid file (~/.gajim/gajim[.profile].pid so that one profile cannot be launched twice) Fixes #1480

This commit is contained in:
Yann Leboulanger 2006-05-26 13:32:52 +00:00
parent 4d024667fd
commit fe7f50cab3
1 changed files with 35 additions and 4 deletions

View File

@ -127,17 +127,47 @@ for o, a in opts:
elif o in ('-p', '--profile'): # gajim --profile name elif o in ('-p', '--profile'): # gajim --profile name
profile = a profile = a
pid_filename = os.path.expanduser('~/.gajim/gajim')
config_filename = os.path.expanduser('~/.gajim/config') config_filename = os.path.expanduser('~/.gajim/config')
if os.name == 'nt': if os.name == 'nt':
try: try:
# Documents and Settings\[User Name]\Application Data\Gajim\logs # Documents and Settings\[User Name]\Application Data\Gajim\logs
config_filename = os.environ['appdata'] + '/Gajim/config' config_filename = os.environ['appdata'] + '/Gajim/config'
pid_filename = os.environ['appdata'] + '/Gajim/gajim'
except KeyError: except KeyError:
# win9x so ./config # win9x so ./config
config_filename = 'config' config_filename = 'config'
pid_filename = 'gajim'
if profile: if profile:
config_filename += '.%s' % profile config_filename += '.%s' % profile
pid_filename += '.%s' % profile
pid_filename += '.pid'
if os.path.exists(pid_filename):
pritext = _('Gajim is already running')
sectext = _('Exit the already running Gajim. Quiting...')
dlg = gtk.MessageDialog(None,
gtk.DIALOG_DESTROY_WITH_PARENT | gtk.DIALOG_MODAL,
gtk.MESSAGE_ERROR, gtk.BUTTONS_OK, message_format = pritext)
dlg.format_secondary_text(sectext)
dlg.run()
dlg.destroy()
sys.exit(3)
# Create pif file
f = open(pid_filename, 'a')
f.close()
def on_exit():
# delete pid file on normal exit
if os.path.exists(pid_filename):
os.remove(pid_filename)
import atexit
atexit.register(on_exit)
parser = optparser.OptionsParser(config_filename) parser = optparser.OptionsParser(config_filename)
@ -1812,7 +1842,10 @@ class Interface:
gobject.timeout_add(500, self.read_sleepy) gobject.timeout_add(500, self.read_sleepy)
if __name__ == '__main__': if __name__ == '__main__':
signal.signal(signal.SIGINT, signal.SIG_DFL) # ^C exits the application def sigint_cb(num, stack):
sys.exit(5)
# ^C exits the application normally to delete pid file
signal.signal(signal.SIGINT, sigint_cb)
if os.name != 'nt': if os.name != 'nt':
# Session Management support # Session Management support
@ -1841,7 +1874,6 @@ if __name__ == '__main__':
gtkgui_helpers.possibly_set_gajim_as_xmpp_handler() gtkgui_helpers.possibly_set_gajim_as_xmpp_handler()
# Migrate old logs if we have such olds logs # Migrate old logs if we have such olds logs
from common import logger from common import logger
from migrate_logs_to_dot9_db import PATH_TO_LOGS_BASE_DIR from migrate_logs_to_dot9_db import PATH_TO_LOGS_BASE_DIR
@ -1869,4 +1901,3 @@ if __name__ == '__main__':
check_paths.check_and_possibly_create_paths() check_paths.check_and_possibly_create_paths()
Interface() Interface()
gtk.main() gtk.main()