import os
from typing import Any
import transformers
from omegaconf import OmegaConf, DictConfig

from distflow.utils.params.training_args import DistflowArguments


def _set_transformers_logging() -> None:
    if os.getenv("distflow_LOG_VERBOSITY", "INFO") in ["DEBUG", "INFO"]:
        transformers.utils.logging.set_verbosity_info()
        transformers.utils.logging.enable_default_handler()
        transformers.utils.logging.enable_explicit_format()


def parse_config(dict_config: DictConfig) -> DistflowArguments:
    """Parse configuration using OmegaConf and convert to a DistflowArguments instance."""
    # Convert OmegaConf config to a dictionary
    distflow_config_dict = OmegaConf.to_container(dict_config, resolve=True)

    # Recursively convert nested configs
    def convert_to_dataclass(obj: Any, dataclass_type: Any):
        if isinstance(obj, dict):
            fields = dataclass_type.__dataclass_fields__
            kwargs = {}
            for name, field_type in fields.items():
                if name in obj:
                    # Handle nested dataclasses
                    if hasattr(field_type.type, "__dataclass_fields__"):
                        kwargs[name] = convert_to_dataclass(obj[name], field_type.type)
                    else:
                        kwargs[name] = obj[name]
            return dataclass_type(**kwargs)
        return obj

    # Convert root config
    distflow_args = convert_to_dataclass(distflow_config_dict, DistflowArguments)
    _set_transformers_logging()
    return distflow_args
