# env_loader.py
"""
Minimal .env loader (no external dependencies).

Reads KEY=VALUE lines from a .env file and loads them into os.environ,
without overriding already-set environment variables.

Compatibility:
- Some scripts call load_env(debug=True)
- Some scripts call load_dotenv(...)
"""

from __future__ import annotations

import os
from pathlib import Path
from typing import Optional


def load_dotenv(
    path: Optional[Path] = None,
    *,
    override: bool = False,
    debug: bool = False,
) -> None:
    """
    Load environment variables from a .env file.

    Args:
        path: Path to .env. If None, tries ".env" in current working directory.
        override: If True, overwrite existing os.environ values.
        debug: If True, print which keys were loaded (values are NOT printed).
    """
    if path is None:
        path = Path(".env")

    path = Path(path)
    if not path.exists():
        if debug:
            print(f"[env_loader] No .env file found at: {path.resolve()}")
        return

    loaded_keys = []
    for raw_line in path.read_text(encoding="utf-8").splitlines():
        line = raw_line.strip()
        if not line or line.startswith("#"):
            continue
        if "=" not in line:
            continue

        key, val = line.split("=", 1)
        key = key.strip()
        val = val.strip().strip('"').strip("'")

        if not key:
            continue

        if key in os.environ and not override:
            continue

        os.environ[key] = val
        loaded_keys.append(key)

    if debug:
        print(f"[env_loader] Loaded {len(loaded_keys)} keys from {path.resolve()}:")
        for k in loaded_keys:
            print(" -", k)


# Backwards-compatible alias (some scripts import load_env)
def load_env(
    path: Optional[Path] = None,
    *,
    override: bool = False,
    debug: bool = False,
) -> None:
    load_dotenv(path, override=override, debug=debug)
