"""
CodeFlow - Simplified flow for code generation without complex toolmaker/classifier
Uses predefined 3-tool workflow: analyze -> design -> implement
"""
import json
from typing import Dict, List, Optional
from src.utils.logsetup import logger
from src.agent import BaseAgent, ToolActorAgent
from src.agent.code_autoagent import CodeAutoAgent
from src.schema.message import Memory


class CodeFlow:
    """Simplified flow for code generation using 3-step process."""
    
    def __init__(self):
        """Initialize with just the essential agents."""
        self.code_agent = None
        self.toolactor = None
        logger.info("🏗️ Initialized CodeFlow for rStar-Coder data generation")
    
    def create_agents(self):
        """Create the necessary agents for code generation."""
        try:
            # Create specialized code agent
            self.code_agent = CodeAutoAgent()
            
            # Create toolactor for tool simulation  
            self.toolactor = ToolActorAgent()
            
            # Connect them
            self.code_agent.set_toolactor(self.toolactor)
            
            logger.info("✅ Created CodeAutoAgent and ToolActorAgent")
            return True
            
        except Exception as e:
            logger.error(f"❌ Failed to create agents: {e}")
            return False
    
    async def run(self, problem: str, gold_code: str = None) -> Dict:
        """
        Run the code generation flow for a single problem.
        
        Args:
            problem: The programming problem statement
            gold_code: The reference solution (for toolactor guidance)
            
        Returns:
            Dictionary in sharegpt format with code output
        """
        try:
            # Create agents if not already created
            if not self.code_agent or not self.toolactor:
                if not self.create_agents():
                    return self._error_response("Failed to initialize agents")
            
            logger.info(f"🚀 Processing code problem: {problem[:100]}...")
            
            # Set gold answer for toolactor guidance
            self.code_agent.gold_answer = gold_code
            
            # Run the agent to generate the solution
            await self.code_agent.run(problem)
            
            # Convert to code-specific sharegpt format
            trajectory = Memory.to_code_sharegpt(
                self.code_agent.messages,
                tools=self.code_agent.tools
            )
            
            logger.info("✅ Code generation completed")
            
            return trajectory
            
        except Exception as e:
            logger.error(f"❌ Error in CodeFlow.run: {e}")
            import traceback
            traceback.print_exc()
            return self._error_response(str(e))
    
    def _error_response(self, error_msg: str) -> Dict:
        """Generate error response in sharegpt format."""
        return {
            "conversations": [
                {"from": "human", "value": "Code generation request"},
                {"from": "gpt", "value": f"<think>\n<observation>\nError occurred: {error_msg}\n</observation>\n</think>\n<code>\n# Error: Could not generate solution\npass\n</code>"}
            ],
            "tools": "[]",
            "error": error_msg
        }
    
    def get_token_summary(self) -> Dict:
        """Get token usage summary from all agents."""
        summary = {
            "code_agent_tokens": 0,
            "toolactor_tokens": 0,
            "total_tokens": 0
        }
        
        try:
            if self.code_agent and hasattr(self.code_agent, 'llm') and self.code_agent.llm:
                code_tokens = getattr(self.code_agent.llm, 'total_input_tokens', 0) + getattr(self.code_agent.llm, 'total_output_tokens', 0)
                summary["code_agent_tokens"] = code_tokens
                
            if self.toolactor and hasattr(self.toolactor, 'toolactor_llm') and self.toolactor.toolactor_llm:
                toolactor_tokens = getattr(self.toolactor.toolactor_llm, 'total_input_tokens', 0) + getattr(self.toolactor.toolactor_llm, 'total_output_tokens', 0)
                summary["toolactor_tokens"] = toolactor_tokens
                
            summary["total_tokens"] = summary["code_agent_tokens"] + summary["toolactor_tokens"]
            
        except Exception as e:
            logger.warning(f"Could not calculate token summary: {e}")
            
        return summary