"""
Problem Analyzer Tool for Code Generation
Analyzes programming problem requirements, constraints, and approach
"""
from typing import Dict
from pydantic import BaseModel, Field


class ProblemAnalyzer(BaseModel):
    """Tool for analyzing programming problems and identifying key requirements."""
    
    name: str = "problem_analyzer" 
    description: str = "Analyzes coding problem requirements, constraints, and identifies the optimal solution approach"
    
    parameters: Dict = Field(default_factory=lambda: {
        "type": "object",
        "properties": {
            "problem_statement": {
                "type": "string", 
                "description": "The complete problem description to analyze"
            }
        },
        "required": ["problem_statement"]
    })

    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_statement: str) -> str:
        """
        Analyze the programming problem and return structured analysis.
        This would normally call an LLM, but for tool registration we return the format.
        """
        return f"""{{
    "problem_type": "algorithm_implementation",
    "input_format": "described in problem",
    "output_format": "described in problem", 
    "constraints": "extracted from problem",
    "key_requirements": ["requirement1", "requirement2"],
    "suggested_approach": "optimal algorithmic approach",
    "complexity_target": "time and space complexity goals"
}}"""