Merge pull request #736 from JackDandy/feature/ChangeSignalHandler

Change improve handling of SIGINT CTRL+C, SIGINT CTRL+BREAK(Windows) …
This commit is contained in:
JackDandy 2016-07-11 18:26:58 +01:00 committed by GitHub
commit 23651e2c57
4 changed files with 44 additions and 26 deletions

View file

@ -106,10 +106,12 @@
* Add "Test NZBGet" client to Search Settings/NZB Search/NZBGet * Add "Test NZBGet" client to Search Settings/NZB Search/NZBGet
* Change include x265 category when searching IPT provider * Change include x265 category when searching IPT provider
* Change init.systemd to use python2 binary and recommended installation paths * Change init.systemd to use python2 binary and recommended installation paths
* Change improve handling of SIGINT CTRL+C, SIGINT CTRL+BREAK(Windows) and SIGTERM
[develop changelog] [develop changelog]
* Change send nzb data to NZBGet for Anizb instead of url * Change send nzb data to NZBGet for Anizb instead of url
* Change ensure KAT URL is available * Change ensure KAT URL is available
* Change revert test_common.py include file placement so Travis builds don't fail
### 0.11.12 (2016-06-20 02:20:00 UTC) ### 0.11.12 (2016-06-20 02:20:00 UTC)

View file

@ -21,16 +21,17 @@
from __future__ import print_function from __future__ import print_function
from __future__ import with_statement from __future__ import with_statement
import time import datetime
import errno
import getopt
import locale
import os
import signal import signal
import sys import sys
import shutil import shutil
import subprocess import subprocess
import os import time
import locale
import datetime
import threading import threading
import getopt
if sys.version_info < (2, 6): if sys.version_info < (2, 6):
print('Sorry, requires Python 2.6 or 2.7.') print('Sorry, requires Python 2.6 or 2.7.')
@ -61,12 +62,15 @@ from sickbeard.tv import TVShow
from sickbeard.webserveInit import WebServer from sickbeard.webserveInit import WebServer
from sickbeard.databases.mainDB import MIN_DB_VERSION, MAX_DB_VERSION from sickbeard.databases.mainDB import MIN_DB_VERSION, MAX_DB_VERSION
from sickbeard.event_queue import Events from sickbeard.event_queue import Events
from sickbeard.exceptions import ex
from lib.configobj import ConfigObj from lib.configobj import ConfigObj
throwaway = datetime.datetime.strptime('20110101', '%Y%m%d') throwaway = datetime.datetime.strptime('20110101', '%Y%m%d')
signal.signal(signal.SIGINT, sickbeard.sig_handler) signal.signal(signal.SIGINT, sickbeard.sig_handler)
signal.signal(signal.SIGTERM, sickbeard.sig_handler) signal.signal(signal.SIGTERM, sickbeard.sig_handler)
if 'win32' == sys.platform:
signal.signal(signal.SIGBREAK, sickbeard.sig_handler)
class SickGear(object): class SickGear(object):
@ -526,6 +530,12 @@ class SickGear(object):
if __name__ == '__main__': if __name__ == '__main__':
if sys.hexversion >= 0x020600F0: if sys.hexversion >= 0x020600F0:
freeze_support() freeze_support()
try:
# start SickGear try:
SickGear().start() # start SickGear
SickGear().start()
except IOError as e:
if e.errno != errno.EINTR:
raise
except Exception as e:
logger.log('SickGear.Start() exception caught %s' % ex(e))

View file

@ -17,35 +17,36 @@
# along with SickGear. If not, see <http://www.gnu.org/licenses/>. # along with SickGear. If not, see <http://www.gnu.org/licenses/>.
from __future__ import with_statement from __future__ import with_statement
import webbrowser
import datetime
import socket
import os
import re
from threading import Lock from threading import Lock
import datetime
import os
import re
import signal
import socket
import webbrowser
# apparently py2exe won't build these unless they're imported somewhere # apparently py2exe won't build these unless they're imported somewhere
import sys
import os.path
import uuid
import ast import ast
import base64 import base64
import os.path
import sys
import uuid
sys.path.insert(1, os.path.abspath('../lib')) sys.path.insert(1, os.path.abspath('../lib'))
from sickbeard import helpers, logger, db, naming, metadata, providers, scene_exceptions, scene_numbering, \ from sickbeard import helpers, encodingKludge as ek
from sickbeard import db, logger, naming, metadata, providers, scene_exceptions, scene_numbering, \
scheduler, auto_post_processer, search_queue, search_propers, search_recent, search_backlog, \ scheduler, auto_post_processer, search_queue, search_propers, search_recent, search_backlog, \
show_queue, show_updater, subtitles, traktChecker, version_checker show_queue, show_updater, subtitles, traktChecker, version_checker
from sickbeard.config import CheckSection, check_setting_int, check_setting_str, ConfigMigrator, minimax from sickbeard.config import CheckSection, check_setting_int, check_setting_str, ConfigMigrator, minimax
from sickbeard.common import SD, SKIPPED from sickbeard.common import SD, SKIPPED
from sickbeard.databases import mainDB, cache_db, failed_db from sickbeard.databases import mainDB, cache_db, failed_db
from sickbeard.exceptions import ex
from sickbeard.providers.generic import GenericProvider
from indexers.indexer_config import INDEXER_TVDB from indexers.indexer_config import INDEXER_TVDB
from indexers.indexer_api import indexerApi from indexers.indexer_api import indexerApi
from indexers.indexer_exceptions import indexer_shownotfound, indexer_exception, indexer_error, \ from indexers.indexer_exceptions import indexer_shownotfound, indexer_exception, indexer_error, \
indexer_episodenotfound, indexer_attributenotfound, indexer_seasonnotfound, indexer_userabort, indexerExcepts indexer_episodenotfound, indexer_attributenotfound, indexer_seasonnotfound, indexer_userabort, indexerExcepts
from sickbeard.exceptions import ex
from sickbeard.providers.generic import GenericProvider
from sickbeard import encodingKludge as ek
from lib.adba.aniDBerrors import (AniDBError, AniDBBannedError) from lib.adba.aniDBerrors import (AniDBError, AniDBBannedError)
from lib.configobj import ConfigObj from lib.configobj import ConfigObj
from lib.libtrakt import TraktAPI from lib.libtrakt import TraktAPI
@ -1376,9 +1377,14 @@ def halt():
def sig_handler(signum=None, frame=None): def sig_handler(signum=None, frame=None):
if isinstance(signum, type(None)): is_ctrlbreak = 'win32' == sys.platform and signal.SIGBREAK == signum
logger.log(u'Signal %i caught, saving and exiting...' % int(signum)) msg = u'Signal "%s" found' % (signal.SIGINT == signum and 'CTRL-C' or is_ctrlbreak and 'CTRL+BREAK' or
signal.SIGTERM == signum and 'Termination' or signum)
if None is signum or signum in (signal.SIGINT, signal.SIGTERM) or is_ctrlbreak:
logger.log('%s, saving and exiting...' % msg)
events.put(events.SystemEvent.SHUTDOWN) events.put(events.SystemEvent.SHUTDOWN)
else:
logger.log('%s, not exiting' % msg)
def save_all(): def save_all():

View file

@ -1,11 +1,11 @@
from sickbeard import common
import unittest import unittest
import sys import sys
import os.path import os.path
sys.path.insert(1, os.path.abspath('..')) sys.path.insert(1, os.path.abspath('..'))
from sickbeard import common
class QualityTests(unittest.TestCase): class QualityTests(unittest.TestCase):