Source code for mechanics_dsl.utils.logging

"""
Logging utilities for MechanicsDSL
"""

import logging
from typing import Optional

# Logging configuration
LOG_FORMAT = "%(asctime)s - %(name)s - %(levelname)s - %(message)s"
LOG_DATE_FORMAT = "%Y-%m-%d %H:%M:%S"


[docs] def setup_logging(level: int = logging.INFO, log_file: Optional[str] = None) -> logging.Logger: """ Setup logging configuration Args: level: Logging level log_file: Optional file to write logs to Returns: Logger instance """ logger = logging.getLogger("MechanicsDSL") logger.setLevel(level) # Clear existing handlers logger.handlers.clear() # Console handler console_handler = logging.StreamHandler() console_handler.setLevel(level) console_formatter = logging.Formatter(LOG_FORMAT, LOG_DATE_FORMAT) console_handler.setFormatter(console_formatter) logger.addHandler(console_handler) # File handler if specified if log_file: file_handler = logging.FileHandler(log_file) file_handler.setLevel(logging.DEBUG) file_formatter = logging.Formatter(LOG_FORMAT, LOG_DATE_FORMAT) file_handler.setFormatter(file_formatter) logger.addHandler(file_handler) return logger
# Global logger instance logger = setup_logging()