"""rLLM: Reinforcement Learning with Language Models

Main package for the rLLM framework.
"""

from typing import TYPE_CHECKING

# NOTE:
# Avoid importing heavyweight deps (e.g., torch) at package import time.
# Some submodules (like `rllm.agents`) pull in torch via chat-template parsing.
# We keep top-level exports via lazy imports in __getattr__.

if TYPE_CHECKING:  # pragma: no cover
    from .agents import Action, BaseAgent, Episode, Step, Trajectory

__all__ = [
    "BaseAgent",
    "Action",
    "Step",
    "Trajectory",
    "Episode",
]


def __getattr__(name: str):
    if name in {"Action", "BaseAgent", "Episode", "Step", "Trajectory"}:
        from .agents import Action, BaseAgent, Episode, Step, Trajectory

        return {"Action": Action, "BaseAgent": BaseAgent, "Episode": Episode, "Step": Step, "Trajectory": Trajectory}[name]
    raise AttributeError(name)
