from loguru import logger
from typing import Optional, Type

from shapely import Point

from gymnasium.utils import colorize

import sys

WARN = 30
ERROR = 40

min_level = 30

import warnings
warnings.filterwarnings("once", "", UserWarning, module=r"^molecule_movement\.")
warnings.filterwarnings("once", "", DeprecationWarning, module=r"^molecule_movement\.")

def log_and_raise(e: BaseException, msg: str, log: bool = True) -> None:
    if log: logger.opt(exception=e).error(msg)
    raise type(e)(msg).with_traceback(sys.exc_info()[2])

def cond_log_and_raise(cond: bool, e: BaseException, msg: str) -> None:
    if not cond:
        log_and_raise(e, msg)

def warn(
    msg: str,
    *args: object,
):
    """Raises a warning to the user if the min_level <= WARN.

    Args:
        msg: The message to warn the user
    """
    if min_level <= WARN:
        warnings.warn(
            colorize(f"WARN: {msg % args}", "yellow"),
            category=UserWarning,
            stacklevel=2,
        )


def deprecated(msg: str):
    """Logs a deprecation warning to users."""
    warnings.warn(msg, category=DeprecationWarning, stacklevel=2)

def log_shapely_point(p: Point) -> dict:
    return {"x":p.x, "y":p.y}
