X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b9b4502bcddeccd794614bf6979d643f9f350877..487e8f756d63c6e68eb300a559eccb504f78c40b:/sdk/python/arvados/commands/_util.py diff --git a/sdk/python/arvados/commands/_util.py b/sdk/python/arvados/commands/_util.py index 075578439d..d10d38eb5b 100644 --- a/sdk/python/arvados/commands/_util.py +++ b/sdk/python/arvados/commands/_util.py @@ -1,6 +1,14 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: Apache-2.0 + 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) @@ -40,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)