initialize logger differently

This commit is contained in:
Sina Atalay 2023-10-08 18:16:08 +02:00
parent 4ddd8581d9
commit fab94208f2
2 changed files with 38 additions and 7 deletions

View File

@ -2,3 +2,41 @@ r"""RenderCV package.
It parses the user input YAML/JSON file and validates the data (checks spelling mistakes, checks if the dates are consistent, etc.). Then, with the data, it creates a $\LaTeX$ file and renders it with [TinyTeX](https://yihui.org/tinytex/). It parses the user input YAML/JSON file and validates the data (checks spelling mistakes, checks if the dates are consistent, etc.). Then, with the data, it creates a $\LaTeX$ file and renders it with [TinyTeX](https://yihui.org/tinytex/).
""" """
# initialize logging:
import logging
class LoggingFormatter(logging.Formatter):
"""
Logging formatter class
"""
grey = "\x1b[38;20m" # debug level
white = "\x1b[37;20m" # info level
yellow = "\x1b[33;20m" # warning level
red = "\x1b[31;20m" # error level
bold_red = "\x1b[31;1m" # critical level
reset = "\x1b[0m"
format = "%(levelname)s | %(message)s"
FORMATS = {
logging.DEBUG: grey + format + reset,
logging.INFO: white + format + reset,
logging.WARNING: yellow + format + reset,
logging.ERROR: red + format + reset,
logging.CRITICAL: bold_red + format + reset,
}
def format(self, record):
log_fmt = self.FORMATS.get(record.levelno)
formatter = logging.Formatter(log_fmt)
return formatter.format(record)
logger = logging.getLogger()
stdout_handler = logging.StreamHandler()
stdout_handler.setLevel(logging.INFO)
stdout_handler.setFormatter(LoggingFormatter())
logger.addHandler(stdout_handler)

View File

@ -3,19 +3,12 @@ This module is a script to run the RenderCV and generate a CV as a PDF.
""" """
import os import os
import logging
from ruamel.yaml import YAML from ruamel.yaml import YAML
from rendercv.data_model import RenderCVDataModel from rendercv.data_model import RenderCVDataModel
from rendercv.rendering import render_template, run_latex from rendercv.rendering import render_template, run_latex
# logging config:
logging.basicConfig(
level=logging.DEBUG,
format="%(name)s - %(levelname)s - %(message)s",
)
input_name = "personal" input_name = "personal"
workspace = os.path.dirname(__file__) workspace = os.path.dirname(__file__)