# scripts/run_slurm.py
"""
Helper to write/persist a SLURM sbatch script for cluster runs.
Adjust partition / resources to your cluster.
"""
import textwrap
import os

SLURM_TEMPLATE = """#!/bin/bash
#SBATCH --job-name=egp_run
#SBATCH --output=logs/%x-%j.out
#SBATCH --error=logs/%x-%j.err
#SBATCH --gres=gpu:1
#SBATCH --cpus-per-task=8
#SBATCH --mem=64G
#SBATCH --time=06:00:00

module load cuda  # adjust to cluster modules
source ~/venv/bin/activate

cd $SLURM_SUBMIT_DIR
python run_pipeline.py --config {config}
"""

def write_slurm(out="run_egp.sbatch", config="configs.py"):
    os.makedirs("logs", exist_ok=True)
    with open(out, "w", encoding="utf-8") as fh:
        fh.write(SLURM_TEMPLATE.format(config=config))
    print(f"Wrote {out}")
