"""File operation utilities."""
import os
import json
import shutil
import logging

logger = logging.getLogger(__name__)


def read_file(file_path: str) -> str:
    """Read file content as string.
    
    Args:
        file_path: Path to the file
        
    Returns:
        File content as string, empty string if file doesn't exist or error occurs
    """
    if not os.path.exists(file_path):
        logger.warning(f"File {file_path} does not exist")
        return ""
    
    try:
        with open(file_path, "r", encoding="utf-8") as file:
            return file.read()
    except Exception as e:
        logger.error(f"Error reading file {file_path}: {e}")
        return ""


def save_file(data: str, filepath: str) -> None:
    """Save string data to file.
    
    Args:
        data: String content to save
        filepath: Path where to save the file
    """
    try:
        os.makedirs(os.path.dirname(filepath), exist_ok=True)
        with open(filepath, "w", encoding="utf-8") as f:
            f.write(data)
        logger.info(f"[save_file] Successfully wrote content to: {filepath}")
    except Exception as e:
        logger.error(f"[save_file] Failed to save to file: {filepath}", exc_info=True)
        raise e


def load_json(path: str) -> dict:
    """Load JSON file.
    
    Args:
        path: Path to JSON file
        
    Returns:
        Parsed JSON data as dict
    """
    with open(path, "r", encoding="utf-8") as f:
        return json.load(f)


def save_json(data: dict, filepath: str, indent: int = 2, ensure_ascii: bool = False) -> None:
    """Save data as JSON file.
    
    Args:
        data: Data to save (must be JSON serializable)
        filepath: Path where to save the JSON file
        indent: JSON indentation level
        ensure_ascii: Whether to ensure ASCII encoding
    """
    try:
        os.makedirs(os.path.dirname(filepath), exist_ok=True)
        with open(filepath, "w", encoding="utf-8") as f:
            json.dump(data, f, indent=indent, ensure_ascii=ensure_ascii)
        logger.info(f"[save_json] Successfully wrote JSON to: {filepath}")
    except Exception as e:
        logger.error(f"[save_json] Failed to save JSON file: {filepath}", exc_info=True)
        raise e


def safe_read_json(path: str, default=None):
    """Safely read JSON file, return default if file doesn't exist or parse fails.
    
    Args:
        path: Path to JSON file
        default: Default value to return if file doesn't exist or parse fails
        
    Returns:
        Parsed JSON data or default value
    """
    try:
        if not os.path.exists(path):
            logger.info(f"[warn] file not found: {path}")
            return default
        with open(path, "r", encoding="utf-8") as f:
            return json.load(f)
    except Exception as e:
        logger.error(f"[error] read json failed: {path} -> {e}")
        return default


def move_file(src: str, dst: str) -> None:
    """Move file from src to dst.
    
    Args:
        src: Source file path
        dst: Destination file path
    """
    try:
        os.makedirs(os.path.dirname(dst), exist_ok=True)
        shutil.move(src, dst)
        logger.info(f"Moved {src} -> {dst}")
    except Exception as e:
        logger.error(f"Failed to move {src}: {e}")


def move_dir(src: str, dst: str) -> None:
    """Move directory from src to dst.
    
    Args:
        src: Source directory path
        dst: Destination directory path
    """
    os.makedirs(os.path.dirname(dst), exist_ok=True)
    shutil.move(src, dst)


def copy_dir(src: str, dst: str) -> None:
    """Copy directory from src to dst.
    
    Args:
        src: Source directory path
        dst: Destination directory path
    """
    os.makedirs(os.path.dirname(dst), exist_ok=True)
    shutil.copytree(src, dst, dirs_exist_ok=True)

