from __future__ import annotations

from pathlib import Path
import re
from typing import Any

from Util.formalization_stats import strip_comments


AXIOM_DECL_RE = re.compile(
    r"^\s*(?:@\[[^\]]+\]\s*)*"
    r"(?:(?:private|protected|noncomputable|unsafe|partial|macro|local)\s+)*"
    r"axiom\b",
    re.M,
)


def find_axiom_decls(path: Path) -> list[dict[str, Any]]:
    text = path.read_text(encoding="utf-8")
    stripped = strip_comments(text)
    lines = text.splitlines()

    decls: list[dict[str, Any]] = []
    for match in AXIOM_DECL_RE.finditer(stripped):
        line = stripped.count("\n", 0, match.start()) + 1
        line_start = stripped.rfind("\n", 0, match.start())
        col = match.start() - line_start
        line_text = lines[line - 1].strip() if 0 <= line - 1 < len(lines) else ""
        decls.append({"line": line, "col": col, "line_text": line_text})

    return decls


def format_axiom_report(axiom_decls: list[dict[str, Any]], max_entries: int = 8) -> str:
    lines: list[str] = []
    for decl in axiom_decls[:max_entries]:
        line = decl.get("line", "?")
        text = decl.get("line_text", "")
        lines.append(f"- line {line}: {text}")
    remaining = len(axiom_decls) - max_entries
    if remaining > 0:
        lines.append(f"- ... and {remaining} more.")
    return "\n".join(lines)


def build_axiom_cleanup_instructions(
    lean_file: Path, axiom_decls: list[dict[str, Any]]
) -> str:
    report = format_axiom_report(axiom_decls)
    return (
        "AXIOM CLEANUP REQUIRED.\n"
        f"The file `{lean_file.as_posix()}` contains Lean `axiom` declarations at:\n"
        f"{report}\n"
        "You must remove every `axiom` declaration and replace it with a legal declaration "
        "(def/lemma/theorem/structure/class/abbrev/instance). If a proof is required, use `by sorry`.\n"
        "Keep edits minimal and do not change unrelated declarations. Ensure no `axiom` keyword remains."
    )
