import argparse
import logging
from pathlib import Path
from pipeline.eval import get_eval_configs
from pipeline.training.train import train_exp
from pipeline.eval.evaluate import eval_exp
from pipeline.training.train_configs import get_exp_configs
from pipeline.training.runtime_resolve import resolve_experiment

logger = logging.getLogger(__file__)

def _parse_args() -> argparse.Namespace:
    parser = argparse.ArgumentParser(description="End-to-end emulator")
    parser.add_argument("--train-config", type=Path, required=True)
    parser.add_argument("--eval-config",   type=Path, required=False)   # optional
    parser.add_argument("--run-eval", action="store_true", help="Run evaluation after training")
    return parser.parse_args()
 
def main():
    args = _parse_args()

    # ----------- Training ---------------------
    train_config, exp_inputs = get_exp_configs(
        config_paths=[
            args.train_config, 
        ]
    )

    experiment = resolve_experiment(
        train_config, 
        exp_inputs
    )

    train_exp(
        train_config=train_config,
        experiment=experiment,
        use_wandb=True
    )
    if args.run_eval:
        if args.eval_config is None:
            raise ValueError("--eval-config is required when --run-eval is used")
        eval_cfg = get_eval_configs( 
            experiment
            )
        eval_exp(
            eval_cfg=eval_cfg,
        )

if __name__ == '__main__':
    main()