Source code for hooks.warnings

# ../hooks/warnings.py

"""Provides warning hooking functionality."""

# =============================================================================
# >> IMPORTS
# =============================================================================
# Python Imports
#   TextWrap
from textwrap import TextWrapper
#   Warnings
import warnings

# Source.Python Imports
#   Hooks
from hooks import _hooks_strings
from hooks import hooks_logger
from hooks.base import _HookBase
from hooks.base import _HookDecorator
from hooks.exceptions import except_hooks
#   Paths
from paths import GAME_PATH


# =============================================================================
# >> ALL DECLARATION
# =============================================================================
__all__ = ('WarningHook',
           '_WarningHooks',
           'warning_hooks',
           )


# =============================================================================
# >> GLOBAL VARIABLES
# =============================================================================
# Get the sp.hooks.warnings logger
hooks_warnings_logger = hooks_logger.warnings

# Get the TextWrapper instance to use for warnings
_text_wrapper = TextWrapper(80, subsequent_indent=' ' * 8)


# =============================================================================
# >> CLASSES
# =============================================================================
class _WarningHooks(_HookBase):
    """Class used to log warnings."""

    def print_warning(
            self, message, category, filename, lineno, file=None, line=None):
        """Called when a warning is encountered.

        This method hooks :obj:`warnings.showwarning` to log all warnings
        and call registered callbacks with the provided arguments.
        """
        # Loop through each callback in the warning list
        for callback in self:

            # Try to call the callback
            try:

                # Call the callback
                callback(message, category, filename, lineno)

            # Was an error encountered?
            except:

                # Log the exception
                except_hooks.print_exception()

        # Get the message to log
        print_message = '\n[SP] ' + _hooks_strings['Warning'].get_string()

        # Add the warning to the message
        print_message += "\n  File '..{0}', line {1}: {2}\n    {3}".format(
            filename.replace(GAME_PATH, ''), lineno,
            category.__name__, '\n'.join(_text_wrapper.wrap(str(message))))

        # Log the warning
        hooks_warnings_logger.log_warning(print_message + '\n')

# The singleton object of the :class:`_WarningHooks` class
warning_hooks = _WarningHooks()

# Set warnings.showwarning to the print_warning method
warnings.showwarning = warning_hooks.print_warning

# Set warnings to only appear once (the first occurrence)
warnings.filterwarnings('once')


[docs]class WarningHook(_HookDecorator): """Register/unregister a function/method for hooking warnings.""" _class_instance = warning_hooks