"""Registry for TSP baseline methods."""

from __future__ import annotations

from dataclasses import dataclass
from typing import Callable, Dict, Iterable, Optional

from .heuristics import eoh_optimal, farthest_insertion, nearest_insertion
from .learning import am_greedy, lehd_two_opt, ortools_solver, pomo_multi_start


SolverHandler = Callable[..., object]


@dataclass(frozen=True)
class MethodSpec:
    name: str
    fullname: str
    category: str  # heuristic | learning | hybrid
    handler: Optional[SolverHandler] = None
    code_provider: Optional[Callable[[], str]] = None
    requires_solver: bool = False
    requires_coords: bool = False
    description: str = ""
    available: bool = True


_REGISTRY: Dict[str, MethodSpec] = {}


def register(spec: MethodSpec) -> None:
    if spec.name in _REGISTRY:
        raise ValueError(f"{spec.name} already registered")
    _REGISTRY[spec.name] = spec


def get(name: str) -> MethodSpec:
    return _REGISTRY[name]


def list_methods(category: str | None = None, available_only: bool = True) -> Iterable[MethodSpec]:
    for spec in _REGISTRY.values():
        if category is not None and spec.category != category:
            continue
        if available_only and not spec.available:
            continue
        yield spec


register(
    MethodSpec(
        name="ni",
        fullname="Nearest Insertion",
        category="heuristic",
        handler=nearest_insertion.solve,
        description="classic insertion construction",
    )
)
register(
    MethodSpec(
        name="fi",
        fullname="Farthest Insertion",
        category="heuristic",
        handler=farthest_insertion.solve,
        description="insertion construction: prioritize farthest city to quickly cover.",
    )
)

register(
    MethodSpec(
        name="eoh_optimal",
        fullname="EoH Optimal",
        category="heuristic",
        code_provider=eoh_optimal.get_code,
        requires_solver=True,
        description="EoH optimal GLS heuristic (requires GLS instance).",
    )
)


