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 ""

    # -------------------------
    # Task: goal only
    # -------------------------
    def get_task(self):
        base_task = (
            "Goal: Implement a step-by-step CVRP construction heuristic that selects the next node at each step "
            "to minimize total travel distance while respecting capacity constraints. "
        )

        if self.context_enabled and self.context:
            return (
                f"{self.context}\n\n"
                f"{base_task}\n"
                "Use the context only to target shared structural weaknesses; do not overfit a single generator."
            )

        return base_task

    def get_func_name(self):
        return "select"

    def get_func_inputs(self):
        return ["current_node", "depot", "unvisited_nodes", "rest_capacity", "demands", "distance_matrix"]

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

    # -------------------------
    # I/O contract: schema only
    # -------------------------
    def get_inout_inf(self):
        return (
            "`current_node`: int (0=depot, 1..n=customers).\n"
            "`depot`: int (always 0).\n"
            "`unvisited_nodes`: np.ndarray of feasible customer IDs (subset of {1..n}).\n"
            "`rest_capacity`: float.\n"
            "`demands`: np.ndarray length (n+1), demands[0]=0.\n"
            "`distance_matrix`: np.ndarray shape (n+1, n+1), symmetric distances.\n\n"
            "Return `next_node`: int, either 0 (return to depot) or an ID contained in `unvisited_nodes`."
        )



    # -------------------------
    # Hard constraints / execution rules
    # -------------------------
    def get_other_inf(self):
        return (
            "No IO/subprocess/network calls.\n"
        )

































# class GetPrompts:
#     def __init__(self):
#         """Initialize prompts with optional context support."""
#         self.context = None  # Evolution context (PSRO-level task description)
#         self.context_enabled = False  # Whether context is enabled
    
#     def set_context(self, context: str = None, enabled: bool = True) -> None:
#         """
#         Set evolution context for PSRO-level task description.
        
#         Args:
#             context: Context string describing the mixed generator distribution
#             enabled: Whether to use context in prompts
#         """
#         self.context = context
#         self.context_enabled = enabled
    
#     def get_context(self) -> str:
#         """Get the evolution context string."""
#         return self.context or ""
    
#     def get_task(self):
#         base_task = (
#             "I need help designing a step-by-step construction heuristic function for CVRP (Capacitated Vehicle Routing Problem). "
#             "The function should select the next node to visit at each step of route construction. "
#             "This is a step-by-step heuristic: at each step, you receive the current state (current node, unvisited feasible nodes, remaining capacity, etc.) "
#             "and must return the ID of the next node to visit. "
#             "The goal is to minimize the total distance while respecting vehicle capacity constraints. "
#             "You can return 0 to return to the depot (start a new route), or return a customer node ID (1..n) that is in the unvisited_nodes array."
#         )
        
#         # Prepend context if enabled
#         if self.context_enabled and self.context:
#             additional_instruction = " Based on the mixed generator distribution described above, you must design a best-response solver strategy."
#             return f"{self.context}\n\n{base_task}{additional_instruction}"
        
#         return base_task
    
#     def get_func_name(self):
#         return "select"
    
#     def get_func_inputs(self):
#         return ["current_node", "depot", "unvisited_nodes", "rest_capacity", "demands", "distance_matrix"]
    
#     def get_func_outputs(self):
#         return ["next_node"]
    
#     def get_inout_inf(self):
#         return (
#             "'current_node' is an int: ID of the current node (0=depot, 1..n=customers). "
#             "'depot' is an int: ID of the depot (always 0). "
#             "'unvisited_nodes' is a np.ndarray: Array of IDs of unvisited feasible nodes (customer nodes: 1..n). "
#             "CRITICAL: This array already contains only feasible nodes (satisfying capacity constraint), so you can only select from these nodes. "
#             "'rest_capacity' is a float: Remaining capacity of the vehicle. "
#             "'demands' is a np.ndarray (length n+1): Demands array, index 0 is depot (demand=0), indices 1..n are customer demands. "
#             "'distance_matrix' is a np.ndarray (n+1) x (n+1): Distance matrix, index 0 is depot. "
#             "The output 'next_node' is an int: ID of the next node to visit. "
#             "It must be either 0 (return to depot) or a node ID that is in the unvisited_nodes array. "
#             "If you return a node not in unvisited_nodes (except 0), it will be treated as invalid."
#         )
    
#     def get_other_inf(self):
#         return (
#             "CRITICAL INPUT VALIDATION: The unvisited_nodes array already contains only feasible nodes (satisfying capacity constraint). "
#             "You can only return a node ID that is in unvisited_nodes, or return 0 (depot). "
#             "If you return an invalid node ID, the system will use a fallback heuristic. "
#             "The function should implement a heuristic algorithm to select the best next node. "
#             "Consider factors like distance to current node, remaining capacity, demand sizes, etc. "
#             "It is important to ensure self-consistency and return valid node IDs. "
#             "Include the following imports at the beginning of the code: 'import numpy as np'. "
#             "The function signature must be exactly: def select(current_node: int, depot: int, unvisited_nodes: np.ndarray, rest_capacity: float, demands: np.ndarray, distance_matrix: np.ndarray) -> int:"
#         )




