"""Code validation utilities for RPA code syntax checking.

This module provides code validation functions to ensure RPA code has valid Python syntax.
"""

import ast
from typing import Tuple

from .agent_utils import print_with_color, write_to_file


def validate_python_syntax(code: str, log_path: str = None) -> Tuple[bool, str]:
    """Validate Python code syntax using AST parsing.
    
    This is a shared utility used by rpa_builder to ensure code has valid Python syntax before execution.
    
    Args:
        code: The Python code string to validate
        log_path: Optional path to save syntax error details
        
    Returns:
        Tuple of (is_valid, error_message):
            - is_valid: True if code has valid syntax, False otherwise
            - error_message: Empty string if valid, error description if invalid
            
    Examples:
        >>> is_valid, msg = validate_python_syntax("print('hello')")
        >>> assert is_valid
        
        >>> is_valid, msg = validate_python_syntax("print('hello'")
        >>> assert not is_valid
        >>> assert "SyntaxError" in msg
    """
    try:
        ast.parse(code)
        print_with_color('✅ RPA code syntax validation passed', 'green')
        return True, ""
    except SyntaxError as e:
        text = e.text.strip('\n') if e.text else ''
        pointer = ''
        if e.offset and e.offset > 0:
            pointer = ' ' * (e.offset - 1) + '^\n'
        
        error_msg_lines = [
            "❌ Syntax Error in Code:",
            f"  Line {e.lineno}: {e.msg}",
            f"  Text: {text}",
        ]
        if pointer:
            error_msg_lines.append("  Offset:")
            error_msg_lines.append(pointer.rstrip('\n'))
        
        error_msg = "\n".join(error_msg_lines)
        print_with_color(error_msg, 'red')
        
        # Optionally save detailed error to file
        if log_path:
            detailed_error = (
                f"{error_msg}\n\n"
                f"Full Code:\n"
                f"{'=' * 60}\n"
                f"{code}\n"
                f"{'=' * 60}\n"
            )
            write_to_file(
                file_path=log_path,
                file_name='syntax_error.txt',
                content=detailed_error
            )
        
        return False, error_msg
    
    except Exception as e:
        error_msg = f"❌ Unexpected error during syntax validation: {e}"
        print_with_color(error_msg, 'red')
        return False, error_msg

