from main import run_agent
import os, glob, argparse
from tqdm import tqdm
import config

import logging
import sys

from datetime import datetime

TIME = datetime.now().strftime('%Y-%m-%d_%H-%M-%S')

def set_log():

    log_dir = "log"
    os.makedirs(log_dir, exist_ok=True)
    log_filename = os.path.join(log_dir, f"{args.task}_{TIME}.log")

    logging.basicConfig(
        filename=log_filename,
        filemode='a',
        level=logging.INFO,
        format='%(asctime)s - %(levelname)s - %(message)s'
    )

    class LoggerWriter:
        def __init__(self, level_func):
            self.level_func = level_func

        def write(self, message):
            message = message.strip()
            if message:
                self.level_func(message)

        def flush(self):
            pass

    sys.stdout = LoggerWriter(logging.info)
    sys.stderr = LoggerWriter(logging.error)


def run_task(task, output_dir, task_type="vision", task_name=None):
    all_task_instances = glob.glob(f"../tasks/{task}/processed/*/" if task_type == "vision" else f"../tasks/{task}/*/")
    output_dir = os.path.join(output_dir, task + '_' + TIME)
    for task_instance in tqdm(all_task_instances[:]):
        print(f"Running task instance: {task_instance}")
        run_agent(task_instance, output_dir, task_type=task_type, task_name=task_name)

        
if __name__ == "__main__":
    
    parser = argparse.ArgumentParser()
    parser.add_argument("--task", type=str, help="The task name")
    args = parser.parse_args()
    
    set_log()
    
    task_type = "vision"
    task_name = None
        
    run_task(args.task, "outputs", task_type=task_type, task_name=task_name)
