from dataclasses import dataclass, field
from pathlib import Path
from typing import Any, Dict, Optional


@dataclass
class EvalRequest:
    """Descriptor for a single evaluation task."""

    op: str
    language: str
    code_path: Optional[Path] = None
    code: Optional[str] = None
    run_name: str = "default"
    metadata: Dict[str, Any] = field(default_factory=dict)
    timeout_s: Optional[int] = None

    def load_code(self) -> str:
        if self.code is not None:
            return self.code
        if self.code_path is None:
            raise ValueError(f"EvalRequest for op '{self.op}' is missing code and code_path")
        return Path(self.code_path).read_text()


@dataclass
class EvalResult:
    """Result payload for a single evaluation task."""

    op: str
    compiled: bool
    correctness: Optional[bool]
    performance: Optional[Dict[str, Any]]
    profiling: Optional[Dict[str, Any]]
    hardware: Optional[str]
    compile_info: Optional[str] = None
    correctness_info: Optional[str] = None
    error: Optional[str] = None
    stdout: Optional[str] = None
    stderr: Optional[str] = None
    metadata: Dict[str, Any] = field(default_factory=dict)
