#!/usr/bin/env python3
"""
Generate an ICLR-style Experiment Setting section and compile the PDF.
All paths are anonymized via ANON_PROJECT_ROOT.
"""

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

client = arxiv.Client()

# ---------- Arg Parsing ----------
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)
EXP_SETTING_TEX = os.path.join(WORK_DIR, "latex", "content", "experiments_setting.tex")
EXP_SETTING_OUTLINE_TEX = os.path.join(WORK_DIR, "latex", "content", "experiments_setting_outline.tex")
BIB_FILE = os.path.join(WORK_DIR, "latex", "iclr2025_conference.bib")

# ---------- Skip if Already Generated ----------
if os.path.exists(EXP_SETTING_TEX) and os.path.getsize(EXP_SETTING_TEX) > 100:
    logger.info("Experiment Setting section already exists; skipping.")
    exit()

# ---------- Load Source Files ----------
IDEAS_JSON = os.path.join(WORK_DIR, "ideas.json")
with open(IDEAS_JSON, "r", encoding="utf-8") as f:
    paper = json.load(f)

# ---------- Aggregate Already-Written Content ----------
paper_already = ""
for sec in ["abstract.tex", "introduction.tex", "background.tex"]:
    sec_path = os.path.join(WORK_DIR, "latex", "content", sec)
    if os.path.exists(sec_path):
        with open(sec_path, "r", encoding="utf-8") as f:
            paper_already += f.read() + "\n\n"

# ---------- Aggregate Experimental Results (from tables) ----------
experiment_results = ""
TABLE_DIR = os.path.join(WORK_DIR, "latex", "table")
if os.path.isdir(TABLE_DIR):
    for fname in sorted(os.listdir(TABLE_DIR)):
        if fname.endswith(".tex"):
            with open(os.path.join(TABLE_DIR, fname), "r", encoding="utf-8") as f:
                experiment_results += f.read() + "\n"

# ---------- Generate Outline ----------
outline_prompt = f"""
Based on the completed sections and the experimental results below, produce a concise outline for the "Experiment Setting" section.

###### Completed Sections BEGIN ######
{paper_already}
###### Completed Sections END ######

###### Experimental Results BEGIN ######
{experiment_results}
###### Experimental Results END ######
"""
if not os.path.exists(EXP_SETTING_OUTLINE_TEX):
    model = ChatAgent(model_name)
    outline = model.chat({"role": "user", "content": outline_prompt})
    with open(EXP_SETTING_OUTLINE_TEX, "w", encoding="utf-8") as f:
        f.write(outline)
else:
    with open(EXP_SETTING_OUTLINE_TEX, "r", encoding="utf-8") as f:
        outline = f.read()

# ---------- Generate Experiment Setting Section ----------
exp_prompt = f"""
Write the "Experiment Setting" section in ICLR academic style using LaTeX.

Guidelines:
- Use paragraph format (no lists).
- Do not reference non-existent figures/tables.
- Cite datasets, baselines, and open-source models; for closed-source models, add links.
- Use correct citation commands: \\cite{{}}, \\citet{{}}, \\citep{{}}; avoid bare "et al."
- Wrap LaTeX content in ```latex```.

###### Outline BEGIN ######
{outline}
###### Outline END ######

###### Completed Paper Parts BEGIN ######
{paper_already}
###### Completed Paper Parts END ######

###### Experimental Results BEGIN ######
{experiment_results}
###### Experimental Results END ######
"""

latex_output = ""
while len(latex_output) < 10:
    model = ChatAgent(model_name)
    latex_output = model.chat_with_latex_retry(exp_prompt)

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

# ---------- Handle Citations ----------
get_cite_from_llm_and_arxiv(latex_output, BIB_FILE)
delete_cite(latex_output, EXP_SETTING_TEX)

logger.info(f"Experiment Setting section saved to {EXP_SETTING_TEX}")

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