#!/usr/bin/python3
"""
Utility functions for clinical dataset construction.

Author(s):
    Anonymized Authors @anonymized-authors

Licensed under the Apache License, Version 2.0. Copyright Anonymized, Inc. 2025.
"""
import json
import os
import pandas as pd
import sys
from contextlib import contextmanager
from functools import wraps
from typing import Any, Callable, Generator


with open(os.path.join(os.path.dirname(__file__), "hivdb_features.json")) as f:
    HIVDB_FEATURES = json.load(f)


def safe_bool(value: Any) -> bool:
    """
    Helper function to standardize boolean representations.
    Input:
        value: the input value to convert.
    Returns:
        The corresponding boolean value.
    """
    if is_null(value):
        return False
    if isinstance(value, (int, float)):
        return bool(value)
    return str(value).lower().strip() in {"true", "1", "t", "yes", "y"}


def is_null(value: Any) -> bool:
    """
    Helper function for determining if a value should be treated as missing.
    Input:
        value: the input value to check.
    Returns:
        Whether the value should be treated as null.
    """
    if str(value).strip().lower() in ["na", "nan"]:
        return True
    if isinstance(value, pd.Timestamp) and value.timestamp() == 0:
        return True
    return pd.isna(value) or (isinstance(value, str) and not value.strip())


def quiet(func: Callable[[Any], Any]) -> Callable[[Any], Any]:
    """
    Function decorator to suppress outputs to stdout and stderr.
    Input:
        func: the function to decorate.
    Returns:
        The decorated function.
    """
    @contextmanager
    def suppress_output() -> Generator:
        with open(os.devnull, "w") as fnull:
            targets = sys.stdout, sys.stderr
            try:
                sys.stdout, sys.stderr = fnull, fnull
                yield
            finally:
                sys.stdout, sys.stderr = targets

    @wraps(func)
    def wrapper(*args: Any, **kwargs: Any) -> Any:
        with suppress_output():
            return func(*args, **kwargs)

    return wrapper
