class GetPrompts:
    def __init__(self):
        self.context = None
        self.context_enabled = False

    def set_context(self, context: str = None, enabled: bool = True) -> None:
        self.context = context
        self.context_enabled = enabled

    def get_context(self) -> str:
        return self.context or ""

    def get_task(self):
        base_task = (
            "Generate a novel function that generates realistic, well-structured CVRP instances that reduce the expected solution quality "
            "achieved by a mixed pool of heuristic solvers, by exploiting general weaknesses "
            "from customer distribution, demand patterns, and capacity constraints (not solver-specific tricks). "
            "Generation protocol (internal; do not explain): "
            "(A) choose a sampling plan that induces hard landscapes (clustered customers, uneven demands, tight capacity); "
            "(B) sample realistic customer locations (avoid extreme clustering or uniform distribution); "
            "(C) assign demands that create capacity challenges (mix of small and large demands); "
            "(D) run lightweight self-checks (demand sum, capacity feasibility, location spread) and resample "
            "with bounded attempts if degenerate. "
            "Output code only."
        )

        if self.context_enabled and self.context:
            additional_instruction = (
                " Use the mixed solver strategy context above only to target shared structural biases across the pool "
                "(do not overfit a single solver)."
            )
            return f"{self.context}\n\n{base_task}{additional_instruction}"

        return base_task

    def get_func_name(self):
        return "generate_instances"

    def get_func_inputs(self):
        return ["seeds", "num_customers", "vehicle_capacity"]

    def get_func_outputs(self):
        return ["instances"]

    def get_inout_inf(self):
        return (
            "`seeds`: array[int] for RNG; `num_customers`: int; `vehicle_capacity`: int. "
            "Return `instances`: list[dict] with keys `depot` (list [x, y] coordinates), `customers` (list of dicts, each with 'coords' [x, y] and 'demand' int), `vehicle_capacity` (int)."
        )



    def get_other_inf(self):
        return (
            "Requirements:\n"
            "1) Use `rng = np.random.default_rng(seed)` per seed; never call `np.random.seed()`.\n"
            "2) All demands must be positive integers.\n"
            "3) Customer coordinates should be in reasonable range (0-100).\n"
            "4) Output variable name must be `instances`.\n"
            "5) Each dict must have exactly keys: `depot`, `customers`, `vehicle_capacity`.\n"
            "6) No solver-specific logic or hard-coded solver IDs.\n"
            "7) Avoid pathological/degenerate instances; keep instances realistic and structured.\n"
            "8) Prefer bounded resampling with quick stats checks over heavy computation.\n"
        )

