"""Utilities for generating run names and handling naming conventions."""

import hashlib
from datetime import datetime


def build_run_name(
    args,
    label_mode: str,
    train_mode: str,
    padding_info: str,
) -> str:
    """Build a run name by hashing all arguments and adding datetime."""
    # Get all attributes from args object and convert to strings
    args_dict = {}
    
    # Handle args object (could be dataclass, namespace, or dict-like)
    if hasattr(args, '__dict__'):
        args_dict.update(args.__dict__)
    elif hasattr(args, '__dataclass_fields__'):
        # Handle dataclass specifically
        for field_name in args.__dataclass_fields__:
            args_dict[field_name] = getattr(args, field_name)
    else:
        # Handle as dict-like object
        args_dict.update(dict(args))
    
    # Add the additional parameters
    args_dict['label_mode'] = label_mode
    args_dict['train_mode'] = train_mode
    args_dict['padding_info'] = padding_info
    
    # Convert all values to strings in a consistent way
    args_strings = []
    for key in sorted(args_dict.keys()):  # Sort for consistency
        value = args_dict[key]
        # Convert value to string representation
        if value is None:
            value_str = "None"
        elif isinstance(value, bool):
            value_str = str(value)
        elif isinstance(value, (int, float)):
            value_str = str(value)
        else:
            value_str = str(value)
        
        args_strings.append(f"{key}={value_str}")
    
    # Create a single string from all args
    args_string = "|".join(args_strings)
    
    # Hash the arguments string
    args_hash = hashlib.md5(args_string.encode()).hexdigest()[:8]
    
    # Add current datetime
    timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
    
    # Build final run name: datetime + hash
    run_name = f"{timestamp}_{args_hash}"
    
    return run_name




def get_label_mode() -> str:
    """Get label strategy string."""
    return "boundary"




def get_padding_info() -> str:
    """Get padding configuration string."""
    return "padstd"  # Always use standard padding
