Source code for wntr.utils.logger
"""Fuctions to set up a default handler for WNTR that will output to the console and to wntr.log."""
import logging
logging.getLogger('wntr').addHandler(logging.NullHandler())
class _LogWrapper(object):  # pragma: no cover
    initialized = None
    def __init__(self):
        self.logger = logger = logging.getLogger('wntr')
        if not len(self.logger.handlers):
            logger.setLevel(logging.DEBUG)
            # warnings/notes are sent to the final report using the logfile
            self.fh = fh = logging.FileHandler('wntr.log', mode='w') 
            fh.setLevel(logging.WARNING)
            # all info is sent to the screen
            self.ch = ch = logging.StreamHandler()
            ch.setLevel(logging.INFO)
            formatter = logging.Formatter(
                '%(name)-12s %(levelname)-8s %(message)s')
            fh.setFormatter(formatter)
            ch.setFormatter(formatter)
            logger.addHandler(fh)
            logger.addHandler(ch)
[docs]
def start_logging():  # pragma: no cover
    """
    Start the wntr logger.
    """
    if _LogWrapper.initialized is None:
        _LogWrapper.initialized = _LogWrapper()