"""
Response parser for extracting structured information from AI responses
"""
import re
import logging
from typing import Optional, Dict, Any
from dataclasses import dataclass

logger = logging.getLogger(__name__)


@dataclass
class ParsedResponse:
    """解析后的响应数据结构"""
    pure_parse: Optional[str] = None
    pure_answer: Optional[str] = None
    is_valid: bool = False
    raw_response: str = ""


class ResponseParser:
    """响应解析器，用于提取和验证AI响应中的结构化信息"""
    
    @staticmethod
    def extract_pure_parse(response: str) -> Optional[str]:
        """提取<pure_parse>标签内容"""
        pattern = r'<pure_parse>(.+?)</pure_parse>'
        match = re.search(pattern, response, re.DOTALL)
        if match:
            content = match.group(1).strip()
            logger.debug(f"Extracted pure_parse: {content}")
            return content
        return None
    
    @staticmethod
    def extract_pure_answer(response: str) -> Optional[str]:
        """提取<pure_answer>标签内容"""
        pattern = r'<pure_answer>(.+?)</pure_answer>'
        match = re.search(pattern, response, re.DOTALL)
        if match:
            content = match.group(1).strip()
            logger.debug(f"Extracted pure_answer: {content}")
            return content
        return None
    
    @staticmethod
    def validate_eval_response(response: str) -> bool:
        """验证EVAL响应是否包含必需的标签"""
        has_parse = ResponseParser.extract_pure_parse(response) is not None
        has_answer = ResponseParser.extract_pure_answer(response) is not None
        
        valid = has_parse or has_answer
        logger.debug(f"Response validation: has_parse={has_parse}, has_answer={has_answer}, valid={valid}")
        
        return valid
    
    @staticmethod
    def parse_eval_response(response: str) -> ParsedResponse:
        """解析EVAL系统的完整响应"""
        pure_parse = ResponseParser.extract_pure_parse(response)
        pure_answer = ResponseParser.extract_pure_answer(response)
        is_valid = ResponseParser.validate_eval_response(response)
        
        parsed = ParsedResponse(
            pure_parse=pure_parse,
            pure_answer=pure_answer,
            is_valid=is_valid,
            raw_response=response
        )
        
        logger.info(f"Parsed EVAL response: valid={is_valid}, has_parse={pure_parse is not None}, has_answer={pure_answer is not None}")
        
        return parsed
    
    # @staticmethod
    # def is_final_answer(pure_answer: str) -> bool:
    #     """判断是否为最终答案（不是None）"""
    #     if not pure_answer:
    #         return False
        
    #     # 检查是否为"None"字符串
    #     if pure_answer.strip().lower() == "none":
    #         return False
        
    #     # 如果有实际内容，则认为是最终答案
    #     return len(pure_answer.strip()) > 0
    
    @staticmethod
    def extract_qa_choices(response: str) -> Optional[Dict[str, str]]:
        """提取QA响应中的选择题选项（如果有的话）"""
        # 匹配 A、B、C 选项格式
        patterns = [
            r'A[\.、：:]\s*(.+?)(?=\s*B[\.、：:]|$)',
            r'B[\.、：:]\s*(.+?)(?=\s*C[\.、：:]|$)',
            r'C[\.、：:]\s*(.+?)(?=\s*$|。)'
        ]
        
        choices = {}
        for i, pattern in enumerate(patterns):
            matches = re.findall(pattern, response, re.DOTALL | re.MULTILINE)
            if matches:
                option_label = chr(65 + i)  # A, B, C
                choices[option_label] = matches[0].strip()
        
        if len(choices) >= 2:  # 至少要有两个选项
            logger.debug(f"Extracted QA choices: {choices}")
            return choices
        
        return None 