import re
import sys
import pandas as pd

def parse_results(filename):
    # Match lines like: "  X Results: X=..., Y=..., Avg=..."
    pattern = re.compile(r"^\s*(.+?) Results:\s*X=(-?[\d.]+),\s*Y=(-?[\d.]+),\s*Avg=(-?[\d.]+)")
    # Match session header lines:
    # - Zenodo: "--- Session N (indy_YYYYMMDD_0x.mat) with ... ---"
    # - MCMAZE: "--- Session N with ... ---" (no parentheses)
    session_pat = re.compile(r"^\s*---\s*Session\s+(\d+)(?:\s*\(([^)]+)\))?")

    results = []
    current_session_num = None
    current_session_name = None

    with open(filename, 'r', encoding='utf-8') as f:
        for line in f:
            # Update session context when we see a session header
            sm = session_pat.match(line)
            if sm:
                current_session_num = int(sm.group(1))
                current_session_name = (sm.group(2).strip() if sm.group(2) else None)
                continue

            # Capture result lines
            match = pattern.match(line)
            if match:
                if current_session_num is None and current_session_name is None:
                    raise ValueError(f"Encountered results before any session header in {filename}: {line.strip()}")

                config, x, y, avg = match.groups()
                # Determine session id
                if current_session_name and current_session_name.lower().endswith('.mat'):
                    session_id = current_session_name  # zenodo-style filename
                else:
                    session_id = f"session {current_session_num}"  # mcmaze-style numbering

                results.append({
                    'session': session_id,
                    'config': config.strip(),
                    'X': float(x),
                    'Y': float(y),
                    'AVG': float(avg)
                })

    if not results:
        print("No matching results found.")
        return

    print(f"{'CONFIG':40s} {'X':>8} {'Y':>8} {'AVG':>8} {'SESSION':>20}")
    print("-" * 90)
    for r in results:
        print(f"{r['config']:40s} {r['X']:8.4f} {r['Y']:8.4f} {r['AVG']:8.4f} {r['session']:>20s}")

    df = pd.DataFrame(results)
    df.to_csv(f"{filename}.csv", index=False)

if __name__ == "__main__":
    for i in ["1","2","3","4","5","6"]:
        parse_results(f"mcmaze_ablation{i}.txt")
