44 lines
1.2 KiB
Python
Raw Normal View History

2025-11-04 05:17:27 +01:00
import logging
import os
from logging.handlers import RotatingFileHandler
2025-11-04 08:09:12 +01:00
2025-11-04 05:17:27 +01:00
from pr.config import LOG_FILE
def setup_logging(verbose=False):
log_dir = os.path.dirname(LOG_FILE)
if log_dir and not os.path.exists(log_dir):
os.makedirs(log_dir, exist_ok=True)
2025-11-04 08:09:12 +01:00
logger = logging.getLogger("pr")
2025-11-04 05:17:27 +01:00
logger.setLevel(logging.DEBUG if verbose else logging.INFO)
if logger.handlers:
logger.handlers.clear()
file_handler = RotatingFileHandler(
2025-11-04 08:09:12 +01:00
LOG_FILE, maxBytes=10 * 1024 * 1024, backupCount=5
2025-11-04 05:17:27 +01:00
)
file_handler.setLevel(logging.DEBUG)
file_formatter = logging.Formatter(
2025-11-04 08:09:12 +01:00
"%(asctime)s - %(name)s - %(levelname)s - %(filename)s:%(lineno)d - %(message)s",
datefmt="%Y-%m-%d %H:%M:%S",
2025-11-04 05:17:27 +01:00
)
file_handler.setFormatter(file_formatter)
logger.addHandler(file_handler)
if verbose:
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.INFO)
2025-11-04 08:09:12 +01:00
console_formatter = logging.Formatter("%(levelname)s: %(message)s")
2025-11-04 05:17:27 +01:00
console_handler.setFormatter(console_formatter)
logger.addHandler(console_handler)
return logger
def get_logger(name=None):
if name:
2025-11-04 08:09:12 +01:00
return logging.getLogger(f"pr.{name}")
return logging.getLogger("pr")