from dataclasses import dataclass
from functools import total_ordering
from typing import List, Any, Optional
from enum import Enum
from src.models.agent_models import ActionType
from dataclasses_json import DataClassJsonMixin

class SelectorStrategy(str, Enum):
    LATEST = "latest"
    BEST = "best"
    LATEST_CORRECT = "latest_correct"
    BEST_CORRECT = "best_correct"
    E_GREEDY = "e_greedy"
    TOP_K_RANDOM = "top_k_random"
    SOFTMAX = "softmax"
    MCTS = "mcts"

@dataclass
class StepCodeTask:
    op: str
    ref_arch: str
    code: str
    err_msg: str
    action: ActionType