"""Base exception class for Expected GradCAM."""

from __future__ import annotations


class ExpectedGradCAMError(Exception):
    """Base exception for all Expected GradCAM errors.

    All custom exceptions inherit from this class and provide:
    - A clear error message explaining what went wrong
    - An optional suggestion for how to fix the issue

    Attributes:
        message: The error message.
        suggestion: Optional suggestion for fixing the error.

    Example:
        >>> raise ExpectedGradCAMError(
        ...     "Failed to compute heatmap",
        ...     suggestion="Check that the model is in eval mode"
        ... )
    """

    def __init__(self, message: str, *, suggestion: str | None = None) -> None:
        """Initialize the exception.

        Args:
            message: The error message describing what went wrong.
            suggestion: Optional suggestion for how to fix the issue.
        """
        self.message = message
        self.suggestion = suggestion

        # Build full message with suggestion if provided
        full_message = message
        if suggestion:
            full_message = f"{message}\n\nSuggestion: {suggestion}"

        super().__init__(full_message)

    def __repr__(self) -> str:
        """Return a detailed representation of the exception."""
        if self.suggestion:
            return f"{self.__class__.__name__}({self.message!r}, suggestion={self.suggestion!r})"
        return f"{self.__class__.__name__}({self.message!r})"
