"""
EVAL validator module
Provides EVAL success validation and puzzle reference retrieval functionality
"""

import re
from typing import Optional


async def validate_eval_success(
    source_text: str, 
    specified_content: str, 
    reference: str = "",
    eval_model: str = "deepseek-v3-250324"
) -> Optional[bool]:
    """
    核心的EVAL成功验证功能（可扩展）
    
    Args:
        source_text: QA响应内容
        specified_content: EVAL的pure_answer内容
        reference: puzzle描述信息（前150词）
        eval_model: 用于验证的模型
        
    Returns:
        bool: True表示验证成功，False表示可能存在问题
        None: API调用失败或无法解析
    """
    try:
        # 导入EVAL_SUCCESS_PROMPT
        from code.prompts.prompts_v2 import EVAL_SUCCESS_PROMPT
        
        # 构建验证提示
        prompt = EVAL_SUCCESS_PROMPT.format(
            source_text=source_text,
            specified_content=specified_content,
            reference=reference
        )
        
        # 创建API客户端进行验证
        from code.core.api_client import UnifiedAPIClient
        api_client = UnifiedAPIClient(eval_model)
        
        # 调用API
        messages = [{"role": "user", "content": prompt}]
        response = await api_client.chat_completion(messages)
        
        if not response.success:
            print(f"  ❌ API调用失败: {response.error}")
            return None  # 返回None表示API调用失败
        
        # 解析judge标签
        pattern = r'<judge>(.+?)</judge>'
        match = re.search(pattern, response.content, re.DOTALL)
        
        if match:
            judge_result = match.group(1).strip().lower()
            return judge_result == 'true'
        else:
            print(f"  ⚠️  未找到judge标签，响应: {response.content[:100]}")
            return None  # 无法解析
            
    except Exception as e:
        print(f"  ❌ 验证失败: {e}")
        return None


def get_puzzle_reference(puzzle, max_words: int = 150) -> str:
    """
    获取puzzle description的前max_words个词作为reference
    
    Args:
        puzzle: puzzle对象，需要包含description属性
        max_words: 最大词数，默认150
        
    Returns:
        str: 截取后的description文本，如果超过max_words会添加"..."
    """
    try:
        if not puzzle or not hasattr(puzzle, 'description'):
            return ""
        
        description = puzzle.description.strip()
        if not description:
            return ""
        
        # 分割成词并取前max_words个
        words = description.split()
        if len(words) <= max_words:
            return description
        else:
            truncated_words = words[:max_words]
            return " ".join(truncated_words) + "..."
            
    except Exception as e:
        print(f"  ⚠️  获取puzzle reference失败: {e}")
        return ""
