import os
import logging
import multiprocessing

import Evaluate_Trajectory_By_LLM

def run_one_pair(dir_in, dir_out):
    # Initialize a separate logger for each subprocess
    log_file = os.path.join(dir_out, 'process.log')
    logging.basicConfig(
        level=logging.INFO,
        format='[%(asctime)s] %(levelname)s %(message)s',
        handlers=[
            logging.FileHandler(log_file, mode='w', encoding='utf-8'),
            logging.StreamHandler()
        ]
    )
    logger = logging.getLogger(__name__)
    try:
        logger.info(f"Start: {dir_in}")
        Evaluate_Trajectory_By_LLM.trajectory_summary.main(dir_in, dir_out)
        logger.info(f"Complete: {dir_in}")
    except Exception as e:
        logger.exception(f"Error in {dir_in}: {e}")


if __name__ == '__main__':
    multiprocessing.freeze_support()  # Required on Windows to support multiprocessing

    trajectory_original_base = "data/trajectory_original/need_summary"
    summary_dir_all = "data/temp/summary_data"

    processes = []

    for dir_child in os.listdir(trajectory_original_base):
        dir_in = os.path.join(trajectory_original_base, dir_child)
        dir_out = summary_dir_all
        os.makedirs(dir_out, exist_ok=True)

        p = multiprocessing.Process(
            target=run_one_pair,
            args=(dir_in, dir_out),
            name=f"proc_{dir_child}"
        )
        p.start()
        processes.append(p)

    for p in processes:
        p.join()

    print("All subdirectories have been processed.")
