"""
Run the DuMuX network tracer example while recording wall time to a file.

Environment variables:
- DUMUX_EXE: path to the example binary
- DUMUX_PARAMS_PATH: path to params.input
- DUMUX_EXAMPLE_DIR: working directory for the run (defaults to the binary's parent)
- DUMUX_RUNTIME_FILE: where to store the elapsed wall time (seconds); defaults to
  <DUMUX_TRACER_OUTPUT basename>_runtime.txt
- DUMUX_TRACER_OUTPUT: used only to derive the default runtime file name
"""

from __future__ import annotations

import os
import subprocess
import time
from pathlib import Path

from gitbud.gitbud import inject_repo_into_sys_path
from experiments.dumux_tracer.config_loader import load_settings

settings = load_settings()

REPO_ROOT = Path(inject_repo_into_sys_path())


def _env_path(name: str, default: Path) -> Path:
    raw = os.environ.get(name)
    return Path(raw) if raw else default


def main() -> None:
    exe = _env_path("DUMUX_EXE", settings.dumux_example)
    params = _env_path("DUMUX_PARAMS_PATH", settings.dumux_params_path)
    workdir = _env_path("DUMUX_EXAMPLE_DIR", exe.parent)
    # Default runtime file is tied to the active settings module (diffusion vs advection).
    runtime_file = _env_path("DUMUX_RUNTIME_FILE", settings.dumux_runtime_file)

    # Keep DuMuX params in sync with Python config.
    text = params.read_text().splitlines()
    for i, line in enumerate(text):
        if line.strip().startswith("TEnd"):
            text[i] = f"TEnd = {settings.time_end}"
        if "DtInitial" in line:
            text[i] = f"DtInitial = {settings.dumux_dt}"
        if "VelocityMagnitude" in line:
            text[i] = f"VelocityMagnitude = {settings.flux_scale}"
        if "DiffusionCoefficient" in line:
            text[i] = f"DiffusionCoefficient = {settings.diffusion_coefficient}"
    params.write_text("\n".join(text) + "\n")

    cmd = [str(exe), str(params)]
    print(f"[dumux run] executing {' '.join(cmd)} in {workdir}")
    start = time.perf_counter()
    proc = subprocess.run(cmd, cwd=workdir)
    elapsed = time.perf_counter() - start

    if proc.returncode != 0:
        print(f"[dumux run] DuMuX exited with code {proc.returncode}")
        raise SystemExit(proc.returncode)

    runtime_file.parent.mkdir(parents=True, exist_ok=True)
    runtime_file.write_text(f"{elapsed}\n")
    print(f"[dumux run] wall time: {elapsed:.3f} s -> {runtime_file}")


if __name__ == "__main__":
    main()
