import logging

def setup_logging(
    execution_name: str = "eval",
    log_level: int = logging.INFO,
    verbose: bool = False
) -> logging.Logger:
    """Configure basic console logging."""
    logger = logging.getLogger("reliability_eval")
    logger.setLevel(log_level)

    # Clear any existing handlers
    if logger.hasHandlers():
        logger.handlers.clear()

    # Create and add console handler with formatter
    formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
    console_handler = logging.StreamHandler()
    console_handler.setFormatter(formatter)
    logger.addHandler(console_handler)

    # Set debug level if verbose
    if verbose:
        logger.setLevel(logging.DEBUG)

    logger.info(f"Starting new execution: {execution_name}")
    return logger

def log_generation_config(logger: logging.Logger, config: dict) -> None:
    """Log generation configuration parameters."""
    logger.info("Generation Configuration:")
    for key, value in config.items():
        logger.info(f" {key}: {value}")

def log_evaluation_pipeline(logger: logging.Logger, pipeline_name: str, config: dict) -> None:
    """Log evaluation pipeline configuration."""
    logger.info(f"Evaluation Pipeline: {pipeline_name}")
    for key, value in config.items():
        logger.info(f" {key}: {value}")