2011-09-06 00:45:53 +00:00
|
|
|
# Copyright 2010-2011 Florent Le Coz <louiz@louiz.org>
|
2010-01-10 20:14:17 +00:00
|
|
|
#
|
|
|
|
# This file is part of Poezio.
|
|
|
|
#
|
|
|
|
# Poezio is free software: you can redistribute it and/or modify
|
2011-09-11 15:10:05 +00:00
|
|
|
# it under the terms of the zlib license. See the COPYING file.
|
2011-09-06 00:45:53 +00:00
|
|
|
|
2010-01-10 20:14:17 +00:00
|
|
|
|
2010-05-18 13:29:02 +00:00
|
|
|
"""
|
|
|
|
Starting point of poezio. Launches both the Connection and Gui
|
|
|
|
"""
|
2010-07-19 23:55:20 +00:00
|
|
|
|
2010-01-21 01:54:50 +00:00
|
|
|
import sys
|
2010-12-26 20:51:14 +00:00
|
|
|
import os
|
2010-08-04 23:54:02 +00:00
|
|
|
import signal
|
2014-04-06 15:17:51 +00:00
|
|
|
import logging
|
2010-07-20 17:25:41 +00:00
|
|
|
|
2013-05-26 18:07:12 +00:00
|
|
|
sys.path.append(os.path.dirname(os.path.abspath(__file__)))
|
|
|
|
|
2011-03-05 20:42:56 +00:00
|
|
|
import singleton
|
2013-08-03 17:27:25 +00:00
|
|
|
|
2011-03-07 18:57:55 +00:00
|
|
|
def main():
|
|
|
|
"""
|
|
|
|
Enter point
|
|
|
|
"""
|
2014-04-06 15:17:51 +00:00
|
|
|
import config
|
|
|
|
config_path = config.check_create_config_dir()
|
|
|
|
config.run_cmdline_args(config_path)
|
|
|
|
config.create_global_config()
|
|
|
|
config.check_create_log_dir()
|
|
|
|
config.setup_logging()
|
|
|
|
config.post_logging_setup()
|
|
|
|
|
|
|
|
from config import options
|
|
|
|
|
2014-04-06 15:26:33 +00:00
|
|
|
import logger
|
|
|
|
logger.create_logger()
|
2014-04-06 15:17:51 +00:00
|
|
|
|
2014-04-06 15:30:52 +00:00
|
|
|
import roster
|
|
|
|
roster.create_roster()
|
|
|
|
|
2014-04-06 15:17:51 +00:00
|
|
|
import core
|
|
|
|
|
|
|
|
log = logging.getLogger('')
|
|
|
|
|
2010-11-09 20:37:39 +00:00
|
|
|
signal.signal(signal.SIGINT, signal.SIG_IGN) # ignore ctrl-c
|
2011-03-07 18:57:55 +00:00
|
|
|
cocore = singleton.Singleton(core.Core)
|
2013-02-28 21:23:25 +00:00
|
|
|
signal.signal(signal.SIGUSR1, cocore.sigusr_handler) # reload the config
|
|
|
|
signal.signal(signal.SIGHUP, cocore.exit_from_signal)
|
|
|
|
signal.signal(signal.SIGTERM, cocore.exit_from_signal)
|
2014-01-30 17:23:44 +00:00
|
|
|
signal.signal(signal.SIGPIPE, cocore.exit_from_signal)
|
2012-10-13 13:14:34 +00:00
|
|
|
if options.debug:
|
|
|
|
cocore.debug = True
|
2011-03-07 18:57:55 +00:00
|
|
|
cocore.start()
|
2012-08-31 20:41:36 +00:00
|
|
|
try:
|
|
|
|
if not cocore.xmpp.start(): # Connect to remote server
|
|
|
|
cocore.on_failed_connection()
|
|
|
|
except:
|
|
|
|
cocore.running = False
|
|
|
|
cocore.reset_curses()
|
|
|
|
print("Poezio could not start, maybe you tried aborting it while it was starting?\n"
|
|
|
|
"If you think it is abnormal, please run it with the -d option and report the bug.")
|
|
|
|
else:
|
2013-08-03 17:27:25 +00:00
|
|
|
log.error('------------------------ new poezio start ------------------------')
|
2012-08-31 20:41:36 +00:00
|
|
|
cocore.main_loop() # Refresh the screen, wait for user events etc
|
2011-03-07 18:57:55 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|