"""
Algorithm Designer Tool for Code Generation
Designs the optimal algorithmic approach with clear step-by-step pseudocode
"""
from typing import Dict
from pydantic import BaseModel, Field


class AlgorithmDesigner(BaseModel):
    """Tool for designing optimal algorithmic solutions with pseudocode."""
    
    name: str = "algorithm_designer"
    description: str = "Designs the optimal algorithmic approach with clear step-by-step pseudocode"
    
    parameters: Dict = Field(default_factory=lambda: {
        "type": "object",
        "properties": {
            "problem_analysis": {
                "type": "string",
                "description": "Analysis results from problem_analyzer tool"
            },
            "approach_type": {
                "type": "string",
                "enum": ["greedy", "dynamic_programming", "two_pointer", "sorting", "graph", "brute_force", "math"],
                "description": "The single best algorithmic approach for this problem"
            }
        },
        "required": ["problem_analysis", "approach_type"]
    })

    def to_param(self) -> Dict:
        """Convert tool to function call format."""
        return {
            "type": "function", 
            "function": {
                "name": self.name,
                "description": self.description,
                "parameters": self.parameters,
            },
        }
    
    async def execute(self, problem_analysis: str, approach_type: str) -> str:
        """
        Design algorithmic solution based on problem analysis.
        This would normally call an LLM, but for tool registration we return the format.
        """
        return f"""{{
    "recommended_approach": "{approach_type}",
    "time_complexity": "O(n log n)",
    "space_complexity": "O(1)", 
    "algorithm_steps": [
        "Step 1: Initialize variables",
        "Step 2: Process input data",
        "Step 3: Apply core algorithm",
        "Step 4: Format and return result"
    ],
    "pseudocode": "1. Parse input\\n2. Apply algorithm\\n3. Return result",
    "edge_cases": ["empty input", "single element", "maximum constraints"]
}}"""