from pathlib import Path
from natsort import natsorted
import re
import shutil
from domains import DOMAIN_NAMES
from pddl.parser.problem import ProblemParser

root_path = Path(__file__).parent.parent
downward_path = root_path / "3rdparty/downward-benchmarks"
llm_p_path = root_path / "3rdparty/llm-pddl"

for domain in DOMAIN_NAMES:
    dest = root_path / "data/domains" / domain
    if dest.exists():
        print(f"Skipping {domain} as it already exists at {dest}")
        continue
        
    src_fd = downward_path / domain
    if not src_fd.exists():
        src_llm_p = llm_p_path / "domains" / domain
        assert src_llm_p.exists(), f"Neither {src_fd} nor {src_llm_p} exists for domain {domain}"

        src = src_llm_p
    else:
        src = src_fd

    print(f"Copying {src} to {dest}")
    shutil.copytree(src, dest)

for domain in DOMAIN_NAMES:
    dest = root_path / "data/domains" / domain

    example_problem = dest / "p_example.pddl"
    if not example_problem.exists():
        print(f"Creating example problem for {domain}")
        for problem_file in dest.glob("*.pddl"):
            try:
                ProblemParser()(problem_file.read_text())
                break
            except Exception as e:
                continue

        print(f"Renaming {problem_file} to {example_problem}")
        shutil.move(problem_file, example_problem)

for domain in DOMAIN_NAMES:
    dest = root_path / "data/domains" / domain
    existing_probs = [re.match(r"p(\d{2})", f.stem) for f in dest.glob("p*.pddl")]
    i = 1 + max([0] + [int(match.group(1)) for match in existing_probs if match])
    print(domain, i)
    for problem_file in natsorted(dest.glob("*.pddl")):
        try:
            ProblemParser()(problem_file.read_text())
        except Exception as e:
            continue

        if "p_example" in problem_file.name:
            # print(f"Skipping example file {problem_file}")
            continue
        if "template" in problem_file.name:
            # print(f"Skipping template file {problem_file}")
            continue
        if len(re.findall(r"\d{2}", problem_file.name)) == 1 and len(re.findall(r"\d+", problem_file.name)) == 1:
            # print(f"Skipping already numbered file {problem_file}")
            continue

        target_file = dest / f"p{i:02d}.pddl"
        print(f"Renaming {problem_file} to {target_file}")
        shutil.move(problem_file, target_file)
        i += 1