Source code for apptools.logger.custom_excepthook

# (C) Copyright 2005-2024 Enthought, Inc., Austin, TX
# All rights reserved.
#
# This software is provided without warranty under the terms of the BSD
# license included in LICENSE.txt and may be redistributed only under
# the conditions described in the aforementioned license. The license
# is also available online at http://www.enthought.com/licenses/BSD.txt
#
# Thanks for using Enthought open source!


# Standard library imports.
import logging
from traceback import format_exception


"""
    To catch exceptions with our own code this code needs to be added
    sys.excepthook = custom_excepthook
"""


[docs]def custom_excepthook(type, value, traceback): """ Pass on the exception to the logging system. """ msg = "Custom - Traceback (most recent call last):\n" list = format_exception(type, value, traceback) msg = "".join(list) # Try to find the module that the exception actually came from. name = getattr(traceback.tb_frame, "f_globals", {}).get( "__name__", __name__ ) logger = logging.getLogger(name) logger.error(msg)