Source code for dynasor.logging_tools

""" This module contains functions and variables to control dynasor's logging

* `logger` - the module logger
"""

import logging
import sys


# This is the root logger of dynasor
logger = logging.getLogger('dynasor')

# Will process all levels of INFO or higher
logger.setLevel(logging.INFO)

# If you know what you are doing you may set this to True
logger.propagate = False

# The dynasor logger will collect events from childs and the default behaviour
# is to print it directly to stdout
ch = logging.StreamHandler(sys.stdout)
ch.setFormatter(logging.Formatter(
    r'%(levelname)s %(asctime)s: %(message)s', datefmt='%Y-%m-%d %H:%M:%S'))
logger.addHandler(ch)


[docs]def set_logging_level(level): """ Alters the logging verbosity logging is handled. level Numeric value * CRITICAL 50 * ERROR 40 * WARNING 30 * INFO 20 * DEBUG 10 * NOTSET 0 Parameters ---------- level : int verbosity level; see `Python logging library <https://docs.python.org/3/library/logging.html>`_ for details """ logger.setLevel(level)