#!/usr/bin/env python3
"""
Generate result tables (LaTeX) for each planned experiment and compile the PDF.
All paths are anonymized via ANON_PROJECT_ROOT.
"""

import re
import json
import tqdm   # type: ignore
import argparse
import requests
import random
import os
from loguru import logger
from concurrent.futures import ThreadPoolExecutor
from create_util import *

parser_manager = ArgParser()
args = parser_manager.add_topic_args().add_model_args().parse()

topic: str = args.topic
topic_description: str = args.topic_description
model_name: str = args.model_name

# ---------- anonymous base directory ----------
BASE_DIR = os.environ.get("ANON_PROJECT_ROOT", "./anonymous_root")
WORK_DIR = os.path.join(BASE_DIR, topic, topic_description)
RESULTS_TEX = os.path.join(WORK_DIR, "latex", "content", "results.tex")
TABLE_DIR = os.path.join(WORK_DIR, "latex", "table")
PROMPT_LOG = os.path.join(WORK_DIR, "prompt_logs.json")

# ---------- skip if results.tex already filled ----------
if os.path.exists(RESULTS_TEX):
    with open(RESULTS_TEX, "r", encoding="utf-8") as f:
        if r"\begin{" in f.read():
            logger.info("Results.tex already populated; skipping.")
            exit()

# ---------- load experiment plan & reference data ----------
IDEAS_JSON = os.path.join(WORK_DIR, "ideas.json")
with open(IDEAS_JSON, "r", encoding="utf-8") as f:
    paper = json.load(f)
experiment_plan = paper["full_experiment_plan"]

ABSTRACT_TEX = os.path.join(WORK_DIR, "latex", "content", "abstract.tex")
with open(ABSTRACT_TEX, "r", encoding="utf-8") as f:
    abstract = f.read()

EXP_SETTINGS_JSON = os.path.join(WORK_DIR, "paper_info_add_experiment_setting.json")
with open(EXP_SETTINGS_JSON, "r", encoding="utf-8") as f:
    ref_experiments = json.load(f)

ref_purpose_settings = [
    f"experiment_purpose: {item.get('experiment_purpose', '')}\n"
    f"experiment_setting: {item.get('experiment_setting', '')}"
    for item in ref_experiments
]
ref_results = [item.get("experiment_result", "") for item in ref_experiments]

# ---------- helper: ensure single table ----------
def clean_table(tex: str) -> str:
    # keep only first table environment
    first = re.search(r"(\\begin\{table\}.*?\\end\{table\})", tex, re.DOTALL)
    return first.group(1) if first else tex

# ---------- generate tables ----------
os.makedirs(TABLE_DIR, exist_ok=True)
prompt_logs = []

for idx, ref_purpose_setting in enumerate(ref_purpose_settings[:6]):
    table_file = os.path.join(TABLE_DIR, f"table_{idx}.tex")
    if os.path.exists(table_file):
        with open(table_file, "r", encoding="utf-8") as f:
            latex_data = f.read()
    else:
        latex_data = ""

    while len(latex_data) < 10:
        prompt = f"""
###### Abstract BEGIN ######
{abstract}
###### Abstract END ######

###### Our Experiment Plan BEGIN ######
{experiment_plan}
###### Our Experiment Plan END ######

###### Reference Experiment BEGIN ######
{ref_purpose_setting}
###### Reference Experiment END ######

Generate a single LaTeX table that reports (synthetic but plausible) numerical results for our experiment plan, inspired by the reference above.

Requirements:
- Only ONE table environment.
- Use \\label{{tab:<descriptive-name>}}.
- Do NOT include \\textit{{Note.}}.
- Wrap table in \\resizebox{{1.0\\linewidth}}{{!}}{{...}}.
"""
        model = ChatAgent(model_name)
        latex_data = model.chat_with_latex_retry(prompt)
        latex_data = clean_table(latex_data)

    with open(table_file, "w", encoding="utf-8") as f:
        f.write(latex_data)

    prompt_logs.append({
        "experiment_setting": ref_purpose_setting,
        "latex_table": latex_data
    })

# ---------- persist prompt logs ----------
with open(PROMPT_LOG, "w", encoding="utf-8") as f:
    json.dump(prompt_logs, f, ensure_ascii=False, indent=4)

# ---------- compile PDF ----------
from create_pdf import create_pdf
create_pdf(topic, topic_description)