mirror of
https://github.com/Doodle3D/Doodle3D-Slicer.git
synced 2025-01-11 19:55:10 +01:00
66 lines
1.4 KiB
Python
66 lines
1.4 KiB
Python
|
import os
|
||
|
import logging
|
||
|
import tempfile
|
||
|
|
||
|
from . import constants
|
||
|
|
||
|
LOG_FILE = None
|
||
|
LOGGER = None
|
||
|
|
||
|
LEVELS = {
|
||
|
constants.DEBUG: logging.DEBUG,
|
||
|
constants.INFO: logging.INFO,
|
||
|
constants.WARNING: logging.WARNING,
|
||
|
constants.ERROR: logging.ERROR,
|
||
|
constants.CRITICAL: logging.CRITICAL
|
||
|
}
|
||
|
|
||
|
|
||
|
def init(filename, level=constants.DEBUG):
|
||
|
"""Initialize the logger.
|
||
|
|
||
|
:param filename: base name of the log file
|
||
|
:param level: logging level (Default value = DEBUG)
|
||
|
|
||
|
"""
|
||
|
global LOG_FILE
|
||
|
LOG_FILE = os.path.join(tempfile.gettempdir(), filename)
|
||
|
with open(LOG_FILE, 'w'):
|
||
|
pass
|
||
|
|
||
|
global LOGGER
|
||
|
LOGGER = logging.getLogger('Three.Export')
|
||
|
LOGGER.setLevel(LEVELS[level])
|
||
|
|
||
|
if not LOGGER.handlers:
|
||
|
stream = logging.StreamHandler()
|
||
|
stream.setLevel(LEVELS[level])
|
||
|
|
||
|
format_ = '%(asctime)s - %(name)s - %(levelname)s: %(message)s'
|
||
|
formatter = logging.Formatter(format_)
|
||
|
|
||
|
stream.setFormatter(formatter)
|
||
|
|
||
|
file_handler = logging.FileHandler(LOG_FILE)
|
||
|
file_handler.setLevel(LEVELS[level])
|
||
|
file_handler.setFormatter(formatter)
|
||
|
|
||
|
LOGGER.addHandler(stream)
|
||
|
LOGGER.addHandler(file_handler)
|
||
|
|
||
|
|
||
|
def info(*args):
|
||
|
LOGGER.info(*args)
|
||
|
|
||
|
def debug(*args):
|
||
|
LOGGER.debug(*args)
|
||
|
|
||
|
def warning(*args):
|
||
|
LOGGER.warning(*args)
|
||
|
|
||
|
def error(*args):
|
||
|
LOGGER.error(*args)
|
||
|
|
||
|
def critical(*args):
|
||
|
LOGGER.critical(*args)
|