X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/0eb72b526bf8bbb011551ecf019f604e17a534f1..e99f026d040c6020dfcc51c6d988cf18d325a530:/sdk/python/arvados/commands/_util.py diff --git a/sdk/python/arvados/commands/_util.py b/sdk/python/arvados/commands/_util.py index d4d9497d3e..d10d38eb5b 100644 --- a/sdk/python/arvados/commands/_util.py +++ b/sdk/python/arvados/commands/_util.py @@ -5,6 +5,10 @@ import argparse import errno import os +import logging +import signal +from future.utils import listitems, listvalues +import sys def _pos_int(s): num = int(s) @@ -44,3 +48,18 @@ def make_home_conf_dir(path, mode=None, errors='ignore'): if mode is not None: os.chmod(abs_path, mode) return abs_path + +CAUGHT_SIGNALS = [signal.SIGINT, signal.SIGQUIT, signal.SIGTERM] + +def exit_signal_handler(sigcode, frame): + logging.getLogger('arvados').error("Caught signal {}, exiting.".format(sigcode)) + sys.exit(-sigcode) + +def install_signal_handlers(): + global orig_signal_handlers + orig_signal_handlers = {sigcode: signal.signal(sigcode, exit_signal_handler) + for sigcode in CAUGHT_SIGNALS} + +def restore_signal_handlers(): + for sigcode, orig_handler in listitems(orig_signal_handlers): + signal.signal(sigcode, orig_handler)